前端页面优化:javascript图片延迟加载
自己写了个简单的图片延迟加载小插件。 功能如下: 页面刷新,当前屏幕图片直接加载真实地址,body被卷去的部分和下方未显示的部分的img均加载通用图片如:loding.gif 随着屏幕上下滚动加载相应在窗口显示的img真实地址。
此处做了一个简单优化,因为延迟加载是计算每个图片距离顶部的距离然后循环赋值的,我在这里给每个图片定义一个flag标记,如果为false,循环时直接continue。这里还可以直接将图片真实地址赋值的img直接从数组中删除,两种写法从代码的臃肿性和执行的流畅性上尚未做对比。 最后附上简单的使用方法。 下面看插件源码:
0 | var loding = function(elm){ |
1 | |
2 | elm = elm instanceof Array ? elm : [elm]; |
3 | |
4 | var i = 0, |
5 | imgArr = []; |
6 | |
7 | for(i; i < elm.length; i += 1){ |
8 | |
9 | everyBox(elm[i]); |
10 | |
11 | } |
12 | |
13 | //给每个盒子进行遍历 |
14 | function everyBox(box){ |
15 | |
16 | var imgs = document.getElementsByTagName('img'); |
17 | |
18 | //遍历每个图片数组 |
19 | for(var i = 0; i < imgs.length; i += 1){ |
20 | |
21 | everyImg(imgs[i]); |
22 | |
23 | } |
24 | |
25 | } |
26 | |
27 | function everyImg(img){ |
28 | |
29 | var temp = document.body.scrollTop || document.documentElement.scrollTop, |
30 | windowH = window.innerHeight; |
31 | |
32 | img.temp = img.offsetTop; |
33 | |
34 | img.tempB = img.offsetTop + img.offsetHeight; |
35 | |
36 | if(img.attributes['data-src']){ |
37 | |
38 | img.ok = img.attributes['data-src'].nodeValue; |
39 | |
40 | img.flag = true; |
41 | |
42 | } |
43 | |
44 | if(img.flag == true){ |
45 | |
46 | if(img.temp < temp + windowH && img.tempB > temp){ |
47 | |
48 | img.src = img.ok; |
49 | |
50 | img.flag = false; |
51 | |
52 | } |
53 | |
54 | imgArr.push(img); |
55 | |
56 | } |
57 | |
58 | } |
59 | |
60 | window.onscroll = function(){ |
61 | |
62 | var temp = document.body.scrollTop || document.documentElement.scrollTop, |
63 | i = 0, |
64 | windowH = window.innerHeight; |
65 | |
66 | for(i; i < imgArr.length; i += 1){ |
67 | |
68 | if(imgArr[i].flag){ |
69 | |
70 | if(imgArr[i].temp < temp + windowH && imgArr[i].tempB > temp){ |
71 | |
72 | imgArr[i].src = imgArr[i].ok; |
73 | |
74 | imgArr[i].flag = false; |
75 | |
76 | } |
77 | |
78 | }else{ |
79 | |
80 | continue; |
81 | |
82 | } |
83 | |
84 | } |
85 | |
86 | |
87 | } |
88 | |
89 | }; |
插件使用方法,在head内引入loding.js 所有需要使用延迟加载的图片请按如下格式编写 <img src="通用图片地址" data-src="真实图片地址"> 调用方法: loading(elm || [elm,elm,elm]); 传入原生dom对象或dom对象数组均可。 插件会直接获取盒子内符合条件的img图片绑定延迟加载 延迟加载在线运行地址
前端页面优化:javascript图片延迟加载的更多相关文章
- Echo.js – 简单易用的 JavaScript 图片延迟加载插件
Echo.js 是一个独立的延迟加载图片的 JavaScript 插件.Echo.js 不依赖第三方库,压缩后不到1KB大小. 延迟加载是提高网页首屏显示速度的一种很有效的方法,当图片元素进入窗口可视 ...
- web前端页面优化——个人见解
web前端页面优化,我们从JavaScript.css.html这3个方面说下,我的见解,希望大神们能有刚好优化方法,一起探讨. 一. 有关javascript方面 优化见解. 1. 首先举个例子: ...
- 前端优化之图片延迟加载(lazyload.js)
要想缩短首屏加载时间,思路一般是减少http请求次数和降低每次的请求量.本文中使用现成的lazyload.js插件,文末会放出下载地址. lazyload.js可以实现图片分批次加载,不是一次性加载完 ...
- Web前端性能优化之图片优化
我自己的Blog:http://blog.cabbit.me/web-image-optimization/ HTTP Archieve有个统计,图片内容已经占到了互联网内容总量的62%,也就是说超过 ...
- 前端性能优化JavaScript篇
关于前端性能优化的讨论一直都很多,包罗的知识也很多,可以说性能优化只有更好,没有最好.前面我写了一篇关于css优化的总结文章,今天再从javascript方面聊一聊. 1.从资源加载方面来说,浏览器的 ...
- javascript图片延迟加载(转载)
<!DOCTYPE HTML><html><head><meta http-equiv="Content-Type" content=&q ...
- 【前端优化】图片延迟加载Lazy-loading的原理与简单实现
1.什么是lazy-loading 图片"懒加载" 为img标签src设置统一的图片链接,而将真实链接地址装在自定义属性中. 所以开始时候图片是不会加载的,我们将满足条件的图片的s ...
- Web性能优化之图片延迟加载
来源:微信公众号CodeL 对于一些图片多,页面长的网页来说,如果每次打开页面加载全部的网页内容,页面加载速度势必会受到影响,如果每次打开网页只将网页可视区域的内容加载给用户 ,将大大提高网页浏览速度 ...
- 简单的Javascript图片延迟加载库Echo.js
简介: 和 Lazy Load 一样,Echo.js 也是一个用于图像延迟加载 JavaScript.不同的是 Lazy Load 是基于 jQuery 的插件,而 Echo.js 不依赖于 jQue ...
随机推荐
- #include <iomanip>
1 setfill 2 setprecision 3 setw 1 setfill setfill( 'c' ) 设填充字符为c ▲setfill(char c) 用法 : 就是在预设宽度中如果已存在 ...
- 看到当年自己学SQL Server 的笔记
数据库 数据量DataBase,不同类型的数据应该放到不同的数据库中, .便于对各个数据类别进行个性管理 .避免命名冲突 .安全性更高; table(表):数据库中的关系指的就是表; 一张表就是一个类 ...
- M记单刷鸡盒副本
今天去M记单刷鸡盒副本,听说此副本掉落最新道具:黑暗之门.鸡翅区和鸡块区全通无压力,鸡腿区难度最大,老一是个灭团点.现在肚子很难受,刚去厕所吐了一把,看来有点高估自己,此副本最好还是组队前往,单刷压力 ...
- linux创建用户和组
linux下创建用户(一) Linux 系统是一个多用户多任务的分时操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统.用户的账号一方面可以帮助系 ...
- 怎样在超级终端和PC之间通过串口传输文件
Windows环境下,通过SecureCRT软件,用串口向ARM开发板发送文件: 输入命令 rz,可以看到如下图所示: 选择路径点击上传即可. 如果是想从Arm开发板中把文件Down下来,则可以按照下 ...
- opcache effect
with open opcache, the monitor cpu idle log , there are so much curl_exec and gzip in our php logic ...
- Windows Server 2008防火墙问题及Sql Server2005用户登录问题
一.Windows Server 2008防火墙问题 1. 问题: 1.在 Windows 安全中心中单击“立即打开”以打开 Windows 防火墙时,会收到以下错误消息:安全中心无法打开 Wind ...
- 【Howie玩docker】-windows下玩docker
Windows下安装toolbox一直没成功,于是投机取巧,用虚拟机手工打造玩docker的方法. 步骤: 安装虚拟机,安装centos 在win下建立共享文件夹,假如是 f:/share 在cent ...
- 【Windows 8 Store App】学习一:获取设备信息
原文http://www.cnblogs.com/java-koma/archive/2013/05/22/3093306.html 通常情况下我们需要知道用户设备的一些信息:deviceId, os ...
- 发布MFC ActiveX控件并实现自动更新
一. 引言 上一篇我们讲了如何使用 VC 2005来开发 MFC ActiveX控件,我们开发 ActiveX控件最终目的是将 ActiveX控件发布出来并嵌入在 Web网页中,随着控件 ...