javascript - JQuery 在显示前加载 div 中的所有图像

标签 javascript jquery css html

我想在实际显示它们之前将每个图像加载到一个 div 中。我有类似的东西:

<div>

<img src="1.jpg" />
<img src="1.jpg" />
<img src="1.jpg" />
<img src="1.jpg" />
<img src="1.jpg" />
<img src="1.jpg" />

</div>

起初我尝试做这样的事情:

$('div img').load(function() {

$('div img').show();


});

或者这个:

$('div').find('img').load(function() {

$('div img').show();

});

不幸的是,这没有用,因为一旦浏览器加载了一张图片,它就会触发该事件。关于如何首先加载所有内容的任何想法?谢谢!

最佳答案

您可以跟踪已加载的图像数量:

var $images = $('div img'),
    preloaded = 0,
    total = $images.length;
$images.load(function() {
    if (++preloaded === total) {
        // Done!
    }
});

关于javascript - JQuery 在显示前加载 div 中的所有图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12810878/

相关文章:

javascript - 在 JavaScript 中填充其他两个字段后填充一个字段

javascript - 尝试使用 NPM 脚本指定 node_env 变量,但出现未定义的属性错误

javascript - jquery 克隆输入看不到值的更改

javascript - 将网站的一部分加载到 iframe 中

jquery - 内容更新时跳页(从较长的内容到较短的内容)

css - 如何使用 CSS :after to Add a Glyphicon Element to an Input

javascript - 快速傅里叶变换Javascript

javascript - 如何升级到React Native 0.57.0版本?

jquery - 如何在 jQuery 中显示加载微调器?

javascript - 当有 3 张或更多幻灯片时轮播工作,但只有 2 张幻灯片时会损坏