I have been trying to find out if an external image is cached on the browser with js, this is the code I have so far:
<html>
<head></head>
<body>
<script src="http://code.jquery.com/jquery-1.4.2.min.js"></script>
<script>
function cached( url ) {
$("#imgx").attr({"src":url});
if(document.getElementById("imgx").complete) {
return true;
} else {
if( document.getElementById("imgx").width > 0 ) return true;
}
return false;
}
</script>
<img id="imgx" src="" />
<script>
$(document).ready(function(){
alert(cached("http://www.google.com/images/srpr/nav_logo80.png"));
});
</script>
</body>
</html>
It works perfectly on firefox but it always returns false on chrome.
Does someone has any idea how to make it work with chrome?
I've rewritten your code in plain JavaScript, to make it more independent on jQuery. The core functionality hasn't changed. Fiddle: http://jsfiddle.net/EmjQG/2/
The first time, I get
false and false
. After I run the code again, I gettrue and false
.Using
.complete
and.height
+.width
gives the expected results (FF 3.6.23, Chromium 14).It's very likely that you've disabled the caching at your Chrome browser. If not, check the HTTP headers of your served image (Is
Cache-control
present?). This header exist at the Google sampleIf you want to detect when an image has (not) finished loading, have a look at this question.