Know when images are done loading in AJAX response
You need to add the load handler in the AJAX callback in order to have it apply to the images that are being loaded via the AJAX call. You may also want to have a timer set to show the content after some interval in case the images get loaded before the load handler is applied.
$.ajax({ ... success: function(data) { var imageCount = $(data).filter('img').length; var imagesLoaded = 0; $(data).hide() .appendTo('#someDiv') .filter('img') .load( function() { ++imagesLoaded; if (imagesLoaded >= imageCount) { $('#someDiv').children().show(); } }); setTimeout( function() { $('#someDiv').children().show() }, 5000 ); }});
This is an updated version of the code tvanfosson provided.
You have to make sure the imageCount
variable is counting a node list and not a string as was the problem in the original code from I can deduce:
$.ajax({ url : 'somePage.html', dataType : "html", success : function(data) { $(data).hide().appendTo('#someDiv'); var imagesCount = $('#someDiv').find('img').length; var imagesLoaded = 0; $('#someDiv').find('img').load( function() { ++imagesLoaded; if (imagesLoaded >= imagesCount) { $('#someDiv').children().show(); } }); var timeout = setTimeout(function() { $('#someDiv').children().show(); }, 5000); } });