1、HTML

<!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>图片预加载</title>
</head> <body>
<div style="display: none">
<img data-src="data:images/arown.png" />
<img data-src="data:images/ewm2.png" />
<img data-src="data:images/hard.png" />
<img data-src="data:images/hard2.png" />
<img data-src="data:images/hard3.png" />
<img data-src="data:images/horizontal.jpg" />
<img data-src="data:images/loading-bj.png" />
<img data-src="data:images/loading-p1.gif" />
<img data-src="data:images/loading_bj.jpg" />
<img data-src="data:images/shoushi-text.png" />
<img data-src="data:images/shoushi.png" />
<img data-src="data:images/suotou.png" />
<img data-src="data:images/suotou2.png" />
<img data-src="data:images/suozi.png" />
<img data-src="data:images/touming.png" />
<img data-src="data:images/ts11.png" />
<img data-src="data:images/ts22.png" />
<img data-src="data:images/units-icons.png" />
<img data-src="data:images/video-img.jpg" />
<img data-src="data:images/1 (1).jpg" />
<img data-src="data:images/1 (10).jpg" />
<img data-src="data:images/1 (100).jpg" />
<img data-src="data:images/1 (101).jpg" />
<img data-src="data:images/1 (102).jpg" />
<img data-src="data:images/1 (103).jpg" />
<img data-src="data:images/1 (104).jpg" />
<img data-src="data:images/1 (105).jpg" />
<img data-src="data:images/1 (106).jpg" />
<img data-src="data:images/1 (107).jpg" />
<img data-src="data:images/1 (108).jpg" />
<img data-src="data:images/1 (109).jpg" />
<img data-src="data:images/1 (11).jpg" />
<img data-src="data:images/1 (110).jpg" />
<img data-src="data:images/1 (111).jpg" />
<img data-src="data:images/1 (112).jpg" />
<img data-src="data:images/1 (113).jpg" />
<img data-src="data:images/1 (114).jpg" />
<img data-src="data:images/1 (115).jpg" />
<img data-src="data:images/1 (116).jpg" />
<img data-src="data:images/1 (117).jpg" />
<img data-src="data:images/1 (118).jpg" />
<img data-src="data:images/1 (119).jpg" />
<img data-src="data:images/1 (12).jpg" />
<img data-src="data:images/1 (120).jpg" />
<img data-src="data:images/1 (121).jpg" />
<img data-src="data:images/1 (122).jpg" />
<img data-src="data:images/1 (123).jpg" />
<img data-src="data:images/1 (124).jpg" />
<img data-src="data:images/1 (125).jpg" />
<img data-src="data:images/1 (126).jpg" />
<img data-src="data:images/1 (127).jpg" />
<img data-src="data:images/1 (128).jpg" />
<img data-src="data:images/1 (129).jpg" />
<img data-src="data:images/1 (13).jpg" />
<img data-src="data:images/1 (130).jpg" />
<img data-src="data:images/1 (131).jpg" />
<img data-src="data:images/1 (132).jpg" />
<img data-src="data:images/1 (133).jpg" />
<img data-src="data:images/1 (134).jpg" />
<img data-src="data:images/1 (135).jpg" />
<img data-src="data:images/1 (136).jpg" />
<img data-src="data:images/1 (137).jpg" />
<img data-src="data:images/1 (138).jpg" />
<img data-src="data:images/1 (139).jpg" />
<img data-src="data:images/1 (14).jpg" />
<img data-src="data:images/1 (140).jpg" />
<img data-src="data:images/1 (141).jpg" />
<img data-src="data:images/1 (142).jpg" />
<img data-src="data:images/1 (143).jpg" />
<img data-src="data:images/1 (144).jpg" />
<img data-src="data:images/1 (145).jpg" />
<img data-src="data:images/1 (146).jpg" />
<img data-src="data:images/1 (147).jpg" />
<img data-src="data:images/1 (148).jpg" />
<img data-src="data:images/1 (15).jpg" />
<img data-src="data:images/1 (16).jpg" />
<img data-src="data:images/1 (17).jpg" />
<img data-src="data:images/1 (18).jpg" />
<img data-src="data:images/1 (19).jpg" />
<img data-src="data:images/1 (2).jpg" />
<img data-src="data:images/1 (20).jpg" />
<img data-src="data:images/1 (21).jpg" />
<img data-src="data:images/1 (22).jpg" />
<img data-src="data:images/1 (23).jpg" />
<img data-src="data:images/1 (24).jpg" />
<img data-src="data:images/1 (25).jpg" />
<img data-src="data:images/1 (26).jpg" />
<img data-src="data:images/1 (27).jpg" />
<img data-src="data:images/1 (28).jpg" />
<img data-src="data:images/1 (29).jpg" />
<img data-src="data:images/1 (3).jpg" />
<img data-src="data:images/1 (30).jpg" />
<img data-src="data:images/1 (31).jpg" />
<img data-src="data:images/1 (32).jpg" />
<img data-src="data:images/1 (33).jpg" />
<img data-src="data:images/1 (34).jpg" />
<img data-src="data:images/1 (35).jpg" />
<img data-src="data:images/1 (36).jpg" />
<img data-src="data:images/1 (37).jpg" />
<img data-src="data:images/1 (38).jpg" />
<img data-src="data:images/1 (39).jpg" />
<img data-src="data:images/1 (4).jpg" />
<img data-src="data:images/1 (40).jpg" />
<img data-src="data:images/1 (41).jpg" />
<img data-src="data:images/1 (42).jpg" />
<img data-src="data:images/1 (43).jpg" />
<img data-src="data:images/1 (44).jpg" />
<img data-src="data:images/1 (45).jpg" />
<img data-src="data:images/1 (46).jpg" />
<img data-src="data:images/1 (47).jpg" />
<img data-src="data:images/1 (48).jpg" />
<img data-src="data:images/1 (49).jpg" />
<img data-src="data:images/1 (5).jpg" />
<img data-src="data:images/1 (50).jpg" />
<img data-src="data:images/1 (51).jpg" />
<img data-src="data:images/1 (52).jpg" />
<img data-src="data:images/1 (53).jpg" />
<img data-src="data:images/1 (54).jpg" />
<img data-src="data:images/1 (55).jpg" />
<img data-src="data:images/1 (56).jpg" />
<img data-src="data:images/1 (57).jpg" />
<img data-src="data:images/1 (58).jpg" />
<img data-src="data:images/1 (59).jpg" />
<img data-src="data:images/1 (6).jpg" />
<img data-src="data:images/1 (60).jpg" />
<img data-src="data:images/1 (61).jpg" />
<img data-src="data:images/1 (62).jpg" />
<img data-src="data:images/1 (63).jpg" />
<img data-src="data:images/1 (64).jpg" />
<img data-src="data:images/1 (65).jpg" />
<img data-src="data:images/1 (66).jpg" />
<img data-src="data:images/1 (67).jpg" />
<img data-src="data:images/1 (68).jpg" />
<img data-src="data:images/1 (69).jpg" />
<img data-src="data:images/1 (7).jpg" />
<img data-src="data:images/1 (70).jpg" />
<img data-src="data:images/1 (71).jpg" />
<img data-src="data:images/1 (72).jpg" />
<img data-src="data:images/1 (73).jpg" />
<img data-src="data:images/1 (74).jpg" />
<img data-src="data:images/1 (75).jpg" />
<img data-src="data:images/1 (76).jpg" />
<img data-src="data:images/1 (77).jpg" />
<img data-src="data:images/1 (78).jpg" />
<img data-src="data:images/1 (79).jpg" />
<img data-src="data:images/1 (8).jpg" />
<img data-src="data:images/1 (80).jpg" />
<img data-src="data:images/1 (81).jpg" />
<img data-src="data:images/1 (82).jpg" />
<img data-src="data:images/1 (83).jpg" />
<img data-src="data:images/1 (84).jpg" />
<img data-src="data:images/1 (85).jpg" />
<img data-src="data:images/1 (86).jpg" />
<img data-src="data:images/1 (87).jpg" />
<img data-src="data:images/1 (88).jpg" />
<img data-src="data:images/1 (89).jpg" />
<img data-src="data:images/1 (9).jpg" />
<img data-src="data:images/1 (90).jpg" />
<img data-src="data:images/1 (91).jpg" />
<img data-src="data:images/1 (92).jpg" />
<img data-src="data:images/1 (93).jpg" />
<img data-src="data:images/1 (94).jpg" />
<img data-src="data:images/1 (95).jpg" />
<img data-src="data:images/1 (96).jpg" />
<img data-src="data:images/1 (97).jpg" />
<img data-src="data:images/1 (98).jpg" />
<img data-src="data:images/1 (99).jpg" /> </div> <div class="loadingpics">
<img id="loadingpics" src="data:images/loading-p1.gif" />
</div> <div class="loadingpics2">
<p class="perc_txt" style="color: #000">0%</p>
</div>
</body>
<script src="js/jquery-2.2.3.min.js"></script>
<script src="js/newpreLoad.js"></script>
<script>
var imgList = [];
$('img[data-src]').each(function () {
var src = $(this).data("src");
imgList.push(src);
})
var loadImg = new PreloadImg(imgList);
loadImg.loadImg();
</script> </html>

2、js

/**
* 自定义预加载图片的类
* param imgList传入的待加载图片数组
* param imgLoadAll待加载总数量
* param count已加载数量
*/
//判断是否微信登陆
var ua = window.navigator.userAgent.toLowerCase();
function isWeiXin() {
if (ua.match(/MicroMessenger/i) == 'micromessenger') {
return true;
} else {
return false;
}
} class PreloadImg {
constructor(imgList) {
this.imgList = imgList;
this.imgLoadAll = this.imgList.length;
this.count = 0;
this.per = 0;
}
// 遍历待加载的图片
loadImg() {
var that = this;
that.imgList.forEach(function (src, i) {
var newsrc = src.substring(src.length - 3);
if (newsrc === 'mp3') {
var audio = new Audio(src);
var loadType = false;
if (isWeiXin()) {
document.addEventListener("WeixinJSBridgeReady", function () {
audio.load();
audio.addEventListener('canplaythrough', function () {
if (!loadType) {
loadType = true;
that.callback();
}
}, false);
}, false);
} else {
audio.load();
audio.addEventListener('canplaythrough', function () {
if (!loadType) {
loadType = true;
console.log('歌曲下载完毕');
that.callback();
}
}, false);
}
} else {
var img = new Image();
img.onload = function () {
that.callback();
}
img.src = src;
}
});
}
// 加载完毕回调
callback() {
var that = this;
that.count = that.count + 1;
console.log(that.count)
that.per = Math.floor((that.count / that.imgLoadAll) * 100);
that.changePer(that.per);
if (that.per == 100) {
console.log('加载完毕');
}
}
// 更改DOM百分比样式
changePer(per) {
$(".perc_txt").html(per + "%");
}
}

用es6类封装的图片预加载技术!的更多相关文章

  1. 再谈javascript图片预加载技术

    图片预加载技术的典型应用: 如lightbox方式展现照片,无疑需要提前获得大图的尺寸,这样才能居中定位,由于javascript无法获取img文件头数据,必须等待其加载完毕后才能获取真实的大小然后展 ...

  2. 转载:用Jquery实现的图片预加载技术,可以实现有序加载和无序加载!

    一.背景 我们在做页面的时候,从用户体验的角度出发,肯定是希望用户以最快的速度看到完整的页面信息,但在实际情况中经常会遇到些问题. 比如受网速影响,页面加载素材的时间比较长,页面会出现短时间的错乱或者 ...

  3. JQ封装图片预加载插件

    我们知道,图片的加载,特别是资源较大的图片,加载相当耗费时间.为了提高用户体验,不得不使用图片预加载技术来提前加载,以提高用户在浏览时的流畅度. 先来弄明白图片的懒加载和预加载的不同: 1)概念:懒加 ...

  4. Javascript图片预加载详解

    预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发布 ...

  5. 利用CSS、JavaScript及Ajax实现图片预加载的三大方法

    预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发布 ...

  6. 利用CSS、JavaScript及Ajax实现图片预加载的三大方法(转)

    预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发布 ...

  7. Javascript图片预加载详解 分类: JavaScript HTML+CSS 2015-05-29 11:01 768人阅读 评论(0) 收藏

    预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发布 ...

  8. 利用CSS、JavaScript及Ajax实现图片预加载的三大方法及优缺点分析

    预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发布 ...

  9. Javascript实现图片预加载【回调函数,多张图片】

    使用JS实现一组图片动画效果或者使用HTML5 Canvas渲染一系列图片等案例中,需要图片全部加载完成方可运行动画效果.此时程序中就会涉及多张图片预加载代码.当接二连三的案例中都涉及图片预加载时,就 ...

随机推荐

  1. Aooms_微服务基础开发平台实战_002_工程构建

    一.关于框架更名的一点说明 最近在做年终总结.明年规划.还有几个项目需要了结.出解决方案,事情还比较多,死了不少脑细胞,距离上一篇文章发出已经过了3天,是不是有些人会认为我放弃了又不搞了,NONO,一 ...

  2. 【转载】C#中自定义Sort的排序规则IComparable接口

    C#中的List集合在排序的时候,如果不使用Lambda表达式进行排序的话,一般调用Sort()方法进行排序,如果希望Sort()方法排序后的结果跟我们预想的效果一致或者按照我们自定义的规则排序,则需 ...

  3. [MySQL] 5.7版本以上group by语句报1055错误问题

    1. 在5.7版本以上mysql中使用group by语句进行分组时, 如果select的字段 , 不是完全对应的group by后面的字段 , 有其他字段 , 那么就会报这个错误 ERROR 105 ...

  4. Ubuntu 18.04 安装java8

    step1: 添加ppa sudo add-apt-repository ppa:webupd8team/java sudo apt-get update step2: 安装oracle-java-i ...

  5. 教我徒弟Android开发入门(四)

    本期知识点: 两大常用布局的简单介绍 在我们的APP使用第三方库 Android Studio常用快捷键 一.两大常用布局 1.LinearLayout线性布局 线性布局,可以垂直显示或者水平显示,设 ...

  6. Java 使用Arrays.sort排序 从大到小排列

    前言 一般情况,我们在Java中给数组排序,比起自己写个冒泡排序,更加喜欢使用Java中自带的sort方法,也就是Arrays.sort方法 但是,这个方法只会将数组从小到大排列,如果我们需要从大到小 ...

  7. 杂牌机搞机之旅(一)——获得root权限(刷入magisk)

    刷机不规范,抱机两行泪,谨慎刷机!! 一般获取root权限,我们都是通过软件来获取的,但是,软件破解root的成功率不是很高,现在,android版本普遍5.0+,大名鼎鼎的magisk可以直接获得r ...

  8. input type date 解决移动端显示placeholder

    在最近的一个项目中使用到了html5的一个新标签属性,type="date"时,发现placeholder属性失效无法使用. 如果是这样的效果,那么客户体验是可想而知的差了. 最后 ...

  9. SpringBoot究竟是如何跑起来的?

    摘要: 神奇的SpringBoot. 原文:SpringBoot 究竟是如何跑起来的? 作者:老钱 Fundebug经授权转载,版权归原作者所有. 不得不说 SpringBoot 太复杂了,我本来只想 ...

  10. document.getElementById(), getElementsByname(),getElementsByClassName(),getElementsByTagName()方法表示什么以及其意义

    <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...