Skip to content

Instantly share code, notes, and snippets.

@pixelhandler
Forked from desandro/jquery.imagesloaded.js
Last active December 20, 2015 07:28
Show Gist options
  • Save pixelhandler/6093120 to your computer and use it in GitHub Desktop.
Save pixelhandler/6093120 to your computer and use it in GitHub Desktop.
images loaded plugin
// $('img.photo',this).imagesLoaded(myFunction)
// execute a callback when all images have loaded.
// needed because .load() doesn't work on cached images
// mit license. paul irish. 2010.
// webkit fix from Oren Solomianik. thx!
// callback function is passed the last image to load
// as an argument, and the collection as `this`
$.fn.imagesLoaded = function( callback ){
var images, len;
if( this.length === 1 && this.localName.toLowerCase() === 'img' ){
images = this;
len = 1;
} else {
images = (this.length) ? this.find('img');
len = images.length;
}
images.bind( 'load', function(){
if( --len <= 0 && typeof callback === 'function' ){
callback.call( images, this );
}
}).each( function(){
// cached images don't fire load sometimes, so we reset src.
if( this.complete || this.complete === undefined ){
var src = this.src;
// webkit hack from http://groups.google.com/group/jquery-dev/browse_thread/thread/eee6ab7b2da50e1f
// data uri bypasses webkit log warning (thx doug jones)
this.src = "data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///ywAAAAAAQABAAACAUwAOw==";
this.src = src;
}
});
return this;
};
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment