2.原生js实现图片懒加载
网上查了很多图片懒加载的内容, 但基本上都是jQuery实现的, 没有说清楚其原理, 所以研究了一下
多的不说, 上代码, 看不明白的建议看下我的上一篇文章<1. 图解浏览器和用户设备的宽高等属性>
HTML部分(图片地址自己随意)
<div>
<img data-src="1.jpg" src="0.gif" alt="">
<img data-src="1.jpg" src="0.gif" alt="">
<img data-src="1.jpg" src="0.gif" alt="">
<img data-src="1.jpg" src="0.gif" alt="">
<img data-src="1.jpg" src="0.gif" alt="">
<img data-src="1.jpg" src="0.gif" alt="">
<img data-src="1.jpg" src="0.gif" alt="">
<img data-src="1.jpg" src="0.gif" alt="">
<img data-src="1.jpg" src="0.gif" alt="">
<img data-src="1.jpg" src="0.gif" alt="">
<img data-src="1.jpg" src="0.gif" alt="">
<img data-src="1.jpg" src="0.gif" alt="">
<img data-src="1.jpg" src="0.gif" alt="">
<img data-src="1.jpg" src="0.gif" alt="">
<img data-src="1.jpg" src="0.gif" alt="">
<img data-src="1.jpg" src="0.gif" alt="">
<img data-src="1.jpg" src="0.gif" alt="">
<img data-src="1.jpg" src="0.gif" alt="">
<img data-src="1.jpg" src="0.gif" alt="">
<img data-src="1.jpg" src="0.gif" alt="">
<img data-src="1.jpg" src="0.gif" alt="">
<img data-src="1.jpg" src="0.gif" alt="">
</div>
JS部分
/*
思路 1.先将图片地址存在"data-src"中
2.图片出现在页面中就将"src"的地址改变
重点 判断图片是否出现在页面中
1.图片距离页面顶部的高度 + 屏幕高度
2.页面距离顶部被卷起来的高度
*/
//可操作部分(建议使用前测试)
var m = 500; //值越大顶部加载的越多
var n = 0; //值越大加载的越多 //选定img元素
var imgs = document.getElementsByTagName("img");
//判断浏览器的高度
var win_h = window.innerHeight||document.documentElement.clientHeight;
//更换图片
function replace(num){
//不能直接将img的"src"等于"data-src",所以先获取"data-src"的值,然后再添加给"src"
imgs[num].setAttribute("src", imgs[num].getAttribute("data-src"));
} //页面滚动时判断滚动到位置(出现在视图窗口),进行加载
window.onscroll = function(){
//页面被卷起来的部分的高度
var scroll_top = window.pageYOffset;
//图片距离页面顶部的高度
for (var i = 0; i < imgs.length; i++) {
var c = imgs[i].offsetTop;
//当图片刚好在可视窗口之内时,替换内容
if (c > (scroll_top - m) && c < (scroll_top + win_h - n)) {
replace(i);
}
}
}
//开始页面就要加载一部分图片
window.onscroll();
虽然比较啰嗦, 但是内容详细. 希望能帮到大家
最终效果如下:
2.原生js实现图片懒加载的更多相关文章
- 页面性能优化-原生JS实现图片懒加载
在项目开发中,我们往往会遇到一个页面需要加载很多图片的情况.我们可以一次性加载全部的图片,但是考虑到用户有可能只浏览部分图片.所以我们需要对图片加载进行优化,只加载浏览器窗口内的图片,当用户滚动时,再 ...
- 原生js实现图片懒加载+加入节流
这两天在学习图片的懒加载实现,看了很多大佬的博客,终于有了点成果.现在用了其中一位大佬的文章中的代码实现了图片懒加载并且在其基础上加入了节流函数. 原理就不多讲了,有需要的可以去大佬的文章看看.大佬文 ...
- js插件---图片懒加载echo.js结合 Amaze UI ScrollSpy 使用
js插件---图片懒加载echo.js结合 Amaze UI ScrollSpy 使用 一.总结 一句话总结:图片懒加载echo.js结合 Amaze UI ScrollSpy 使用的效果就是:懒加载 ...
- js插件---图片懒加载lazyload
js插件---图片懒加载lazyload 一.总结 一句话总结:使用异常简单,src里面放加载的图片,data-original里面放原图片,不懂的位置去官网或者github找API就好. 1.laz ...
- JS实现图片懒加载插件
一.前言 我在前几篇博客的记录中,有说自己在做一个图片懒加载的功能,然后巴拉巴拉的遇到哪些问题,结果做完了也没对懒加载这个功能做一些记录,所以这篇文章主要针对我所实现的思路,以及代码做个记录,实现不佳 ...
- js, javascript 图片懒加载 实例代码
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- js实现图片懒加载
大型购物网站都会采用图片懒加载技术来优化网站首页打开速度,以提高用户体验,那么具体是怎么实现的呢,我们一探究竟. html结构(div包裹一层用来显示背景图片,等待图片加载完成后,显示真实图片) &l ...
- Js 之图片懒加载插件
一.PC端(lazyload) 1.引入js文件 <script src="//ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.m ...
- js实现图片懒加载原理
原理 图片懒加载是前端页面优化的一种方式,在页面中有很多图片的时候,图片加载就需要很多时间,很耗费服务器性能,不仅影响渲染速度还会浪费带宽,为了解决这个问题,提高用户体验,所以就出现了懒加载这种方式来 ...
随机推荐
- 3.智能快递柜(通信篇-HTTP)
1.智能快递柜(开篇) 2.智能快递柜(终端篇) 3.智能快递柜(通信篇-HTTP) 4.智能快递柜(通信篇-SOCKET) 5.智能快递柜(通信篇-Server程序) 6.智能快递柜(平台篇) 7. ...
- Qt在window下的环境变量PATH的配置
Qt在window下的环境变量PATH的配置 路劲: C:\Qt\Qt5.6.0\5.6\mingw49_32\bin C:\Qt\Qt5.6.0\Tools\mingw492_32\bin 发布Qt ...
- -bash: /home/java/jdk1.8.0_221/bin/java: 权限不够
1)进入存放jdk文件的文件夹路径我这里是 usr/local/jdk/2)输入命令 chmod 777 jdk1.8.0_221/bin/java修改权限3)再次输入 java -version 成 ...
- firefox56 版本中的 Selenium IDE 无法导出脚本问题
firefox:56 Slenium IDE :3系列 问题:Selenium IDE 没有工具栏,无法导出录制的脚本,这给自动化测试工作带来了极大的不便. 解决办法:将firefox 降级 (只有5 ...
- 23.Java基础_ArrayList类
ArrayList类的构造和使用方法 import java.util.ArrayList; public class test { public static void main(String[] ...
- Centos 7+KVM(Windows Server 2008 r2 )
KVM虚拟机 Kernel-based Virtual Machine的简称,是一个开源的系统虚拟化模块,自Linux 2.6.20之后集成在Linux的各个主要发行版本中.它使用Linux自身的调度 ...
- monkey和monkeyrunner的区别
简单来说: 1.monkey是在设备或模拟器直接运行adb shell命令生成随机事件来进行测试 2.monkeyrunner是通过API发送特定的命令和事件来控制设备 为了支持黑盒自动化测试的场景, ...
- [C3] Andrew Ng - Neural Networks and Deep Learning
About this Course If you want to break into cutting-edge AI, this course will help you do so. Deep l ...
- jenkins配置自动部署java程序
任务背景 该项目包含4个程序包:a.jar,b.jar,c.jar,d.jar,每次启动前需要修改程序中的配置文件(修改数据源配置),然后按照先后顺序启动. 任务目标 1.利用jenkins拉取代码, ...
- 关于webpack的面试题
随着现代前端开发的复杂度和规模越来越庞大,已经不能抛开工程化来独立开发了,如react的jsx代码必须编译后才能在浏览器中使用:又如sass和less的代码浏览器也是不支持的. 而如果摒弃了这些开发框 ...