在jQuery中,当你这样做:
$(function() {
alert("DOM is loaded, but images not necessarily all loaded");
});
它等待DOM加载并执行您的代码。如果没有加载所有的图像,那么它仍然执行代码。这显然是我们在初始化任何DOM内容(如显示或隐藏元素或附加事件)时所需要的。
假设我想要一些动画我不想让它运行直到所有图像都加载完毕。jQuery中有官方的方法来做到这一点吗?
最好的方法是使用<body onload="finished()“>,但除非迫不得已,我真的不想这么做。
注意:在ie浏览器的jQuery 1.3.1中有一个bug,它实际上是在执行$function(){}内的代码之前等待所有图像加载。所以如果你正在使用这个平台,你会得到我正在寻找的行为,而不是上面描述的正确行为。
我建议使用imagesLoaded.js javascript库。
为什么不使用jQuery的$(window).load()?
正如在https://stackoverflow.com/questions/26927575/why-use-imagesloaded-javascript-library-versus-jquerys-window-load/26929951上的回答
这是一个范围问题。imagesLoaded允许你瞄准一组图像,而$(window).load()瞄准所有资产——包括所有图像、对象、.js和.css文件,甚至iframe。imagesLoaded很可能比$(window).load()更早触发,因为它的目标是较小的资产集。
其他使用图像加载的好理由
IE8+正式支持
许可证:MIT许可证
依赖性:没有
重量(缩小&压缩):7kb缩小(轻!)
下载构建器(有助于减肥):不需要,已经很小了
在Github上:是的
社区和贡献者:相当大,4000多名成员,尽管只有13名贡献者
历史和贡献:稳定,相对较老(自2010年以来),但仍然活跃的项目
资源
项目在github: https://github.com/desandro/imagesloaded
官方网站:http://imagesloaded.desandro.com/
检查图像是否在JavaScript中加载(无错误)
https://stackoverflow.com/questions/26927575/why-use-imagesloaded-javascript-library-versus-jquerys-window-load
Imagesloaded javascript库:浏览器和设备支持什么?
使用imagesLoaded PACKAGED v3.1.8(最小化时6.8 Kb)。这是一个相对较老的项目(自2010年以来),但仍然是活跃的项目。
你可以在github上找到:
https://github.com/desandro/imagesloaded
他们的官方网站:
http://imagesloaded.desandro.com/
为什么它比使用更好:
$(window).load()
因为您可能希望动态加载图像,就像这样:jsfiddle
$('#button').click(function(){
$('#image').attr('src', '...');
});