首頁 >web前端 >js教程 >在JS中如何實現非首屏圖片延遲加載

在JS中如何實現非首屏圖片延遲加載

亚连
亚连原創
2018-06-13 14:50:071824瀏覽

下面我就為大家分享一篇用JS實現非首屏圖片延遲加載的示例,具有很好的參考價值,希望對大家有所幫助。

目標

#減少資源載入可以明顯的最佳化頁面載入的速度,所以可以減少頁面載入時立即下載的圖片的數量,以提高頁面載入速度,其他的圖片在需要的時候再進行載入。

想法

想要實現以上的目標,有幾個地方需要思考。

1、如何判斷哪些圖片需要立即加載,哪些可以晚點再加載?

2、如何控制圖片在指定的時候載入?

對於第一個問題,頁面開啟就會被使用者看到的圖片肯定需要立即加載,其他的可以延後。即在視窗中的圖片需要立即載入。那麼該如何判斷圖片是否在視窗內呢? getBoundingClientRect可以傳回元素的大小及其相對於視窗的位置(詳細說明)

 

可以透過圖中top和right的值判斷圖片是否在視窗中。

對於第二個問題,先不給img指定src,而是將圖片連結位址存放再元素的src屬性(自訂)中,需要載入的時候再賦值給src,才會開始下載圖片。

實作

想法有了,我們開始實作。用以下HTML進行測試


 <p class="container">
 <h1>图片懒加载</h1>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <img src="" alt="" class="lazy-img" src="http://c.hiphotos.baidu.com/zhidao/pic/item/1f178a82b9014a909461e9baa1773912b31bee5e.jpg">
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <img src="" alt="" class="lazy-img" src="http://img2.niutuku.com/desk/1208/1718/ntk-1718-66531.jpg">
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <img src="" alt="" class="lazy-img" src="http://2t.5068.com/uploads/allimg/151105/48-151105112944-51.jpg">
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <img src="" alt="" class="lazy-img" src="http://img2.niutuku.com/desk/anime/4654/4654-4708.jpg">
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <img src="" alt="" class="lazy-img" src="http://img2.niutuku.com/desk/1208/1721/ntk-1721-66572.jpg">
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>
 <p>测试性配文,测试图片懒加载</p>

 </p>

html中連結都來自百度圖片,可在network中觀察是否加載,這裡忽略樣式。依照之前的思路,有以下程式碼

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

下面就是如何實現lazyLoad

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

透過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如何實作碰撞偵測

#使用vue-meta如何管理頭部標籤

在vue中如何修改a標籤樣式?

有關ES6的7個實用技巧有哪些?

以上是在JS中如何實現非首屏圖片延遲加載的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn