js 或者 jq怎么判断所有图片加载完成?

js 或者 jq怎么判断所有图片加载完成?

阅读 4.3k
5 个回答

用document的onload事件,或者如果只关心图片,就挂接img的load事件。

$('img').on('load', function() {
    // xxx
});
 /**
 *加载图片
 * @param arr ['图片链接']
 * @returns {Array}
 */
function loadImg(arr) {
    var newimages = [];
    var arr = (typeof arr != "object") ? [arr] : arr  //确保参数总是数组
    for (var i = 0; i < arr.length; i++) {
        newimages[i] = new Promise(function (resolve, reject) {
            var image = new Image();
            image.addEventListener('load', function listener() {
                resolve(image);
                this.removeEventListener('load', listener);
            });
            image.src = arr[i];
            image.addEventListener('error', reject);
        })
    }
    return newimages
}
Promise.all(loadImg(listPics)).then(function () {
    console.log('图片加载完成')
});

之前项目使用过的加载全部图片的处理方案,希望能帮助你

用到js图片的onload事件,jq的load

那得预先知道图片的数量了,加一个计数器,在load回调函数中

var i = 0;
$('img').load(function(){
    i++;
    if(i==x){
        ...
    }
});
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题