JS如何实现非首屏图片延迟加载

这篇文章将为大家详细讲解有关JS如何实现非首屏图片延迟加载,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

成都创新互联专注于龙马潭企业网站建设,响应式网站,商城建设。龙马潭网站建设公司,为龙马潭等地区提供建站服务。全流程按需定制设计,专业设计,全程项目跟踪,成都创新互联专业和态度为您提供的服务

js的作用是什么

1、能够嵌入动态文本于HTML页面。2、对浏览器事件做出响应。3、读写HTML元素。4、在数据被提交到服务器之前验证数据。5、检测访客的浏览器信息。6、控制cookies,包括创建和修改等。7、基于Node.js技术进行服务器端编程。

目标

减少资源加载可以明显的优化页面加载的速度,所以可以减少页面载入时立即下载的图片的数量,以提高页面加载速度,其他的图片在需要的时候再进行加载。

思路

想要实现以上的目标,有几个地方需要思考。

1、如何判断哪些图片需要立即加载,哪些可以晚些再加载?

2、如何控制图片在指定的时候加载?

对于第一个问题,页面打开就会被用户看到的图片肯定需要立即加载,其他的可以延后。即在视窗中的图片需要立即加载。那么如何判断图片是否在视窗内呢?getBoundingClientRect可以返回元素的大小及其相对于视口的位置(详细说明)

JS如何实现非首屏图片延迟加载

可以通过图中top和right的值判断图片是否在视窗中。

对于第二个问题,先不给img指定src,而是将图片链接地址存放再元素的data-src属性(自定义)中,需要加载的时候再赋值给src,才会开始下载图片。

实现

思路有了,我们开始实现。用以下HTML进行测试

 
 

图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

   

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

   

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

   

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

   

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

   

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

测试性配文,测试图片懒加载

 

html中链接都来自百度图片,可在network中观察是否加载,这里忽略样式。按照之前的思路,有以下代码

//所有的图片
 var imgs = document.querySelectorAll('.lazy-img');
 //首屏图片加载
 lazyLoad(imgs)
 //剩余图片加载---监听滚动事件
 window.addEventListener('scroll',function(){
 //滚动事件触发太频繁了,所以加上节流
 throttle(lazyLoad(imgs),200,500)
 })
 }

下面就是如何实现lazyLoad

function lazyLoad(imgs,offset){
 offset = offset || 100;
 if (!imgs || imgs.length < 1) {
 console.log('imgs为空');
 return ;
 }
 [].slice.call(imgs).forEach(function(element,index){
 //元素的DomRect
 var rect = element.getBoundingClientRect()
 //出现在视窗中
 if (rect.top <= window.innerHeight + offset && rect.right > 0) {
 element.setAttribute('src',element.getAttribute('data-src'))
 }
 })
}

通过window.innerHeight获取到视窗的高度,当元素距离视窗上边沿为offset时,加载图片;其中offset为指定的偏移距离。

节流函数如下

function throttle (fn, delay, atleast) {
 let timer = null
 let startTime = new Date()

 return function () {
 let context = this
 let args = arguments
 let curTime = new Date()

 clearTimeout(timer)
 if (curTime - startTime >= atleast) {
 fn.apply(context, args) // apply 指定函数指向的 上下文(this) 和 参数列表
 startTime = curTime
 } else {
 timer = setTimeout(function () {
 fn.apply(context, args)
 startTime = curTime
 }, delay)
 }
 }
 }

效果

页面载入完成,只加载了一张图片

JS如何实现非首屏图片延迟加载

向下滚动到指定位置,才会依次加载后续图片

JS如何实现非首屏图片延迟加载

关于“JS如何实现非首屏图片延迟加载”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。


文章题目:JS如何实现非首屏图片延迟加载
URL链接:http://scyanting.com/article/jpghjg.html

其他资讯