您好,登錄后才能下訂單哦!
這篇文章主要介紹js前端如何實(shí)現(xiàn)圖片懶加載,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!
思路:
將頁面里所有img屬性src屬性用data-xx代替,當(dāng)頁面滾動(dòng)直至此圖片出現(xiàn)在可視區(qū)域時(shí),用js取到該圖片的data-xx的值賦給src。
關(guān)于各種寬高:
頁可見區(qū)域?qū)挘?document.body.clientWidth;
網(wǎng)頁可見區(qū)域高: document.body.clientHeight;
網(wǎng)頁可見區(qū)域?qū)挘?document.body.offsetWidth (包括邊線的寬);
網(wǎng)頁可見區(qū)域高: document.body.offsetHeight (包括邊線的寬);
網(wǎng)頁正文全文寬: document.body.scrollWidth;
網(wǎng)頁正文全文高: document.body.scrollHeight;
網(wǎng)頁被卷去的高: document.body.scrollTop;
網(wǎng)頁被卷去的左: document.body.scrollLeft;
網(wǎng)頁正文部分上: window.screenTop;
網(wǎng)頁正文部分左: window.screenLeft;
屏幕分辨率的高: window.screen.height;
屏幕分辨率的寬: window.screen.width;
屏幕可用工作區(qū)高度: window.screen.availHeight;
示例:
jqueryLazyload方式
下載地址:https://github.com/helijun/helijun/blob/master/plugin/lazyLoad/jquery.lazyload.js
<section class="module-section" id="container"> <img class="lazy-load" data-original="../static/img/loveLetter/teacher/teacher1.jpg" width="640" height="480" alt="測(cè)試懶加載圖片"/> </section>
require.config({ baseUrl : "/static", paths: { jquery:'component/jquery/jquery-3.1.0.min' jqueryLazyload: 'component/lazyLoad/jquery.lazyload',//圖片懶加載 }, shim: { jqueryLazyload: { deps: ['jquery'], exports: '$' } } });
require( [ 'jquery', 'jqueryLazyload' ], function($){ $(document).ready(function() { $("img.lazy-load").lazyload({ effect : "fadeIn", //漸現(xiàn),show(直接顯示),fadeIn(淡入),slideDown(下拉) threshold : 180, //預(yù)加載,在圖片距離屏幕180px時(shí)提前載入 event: 'click', // 事件觸發(fā)時(shí)才加載,click(點(diǎn)擊),mouseover(鼠標(biāo)劃過),sporty(運(yùn)動(dòng)的),默認(rèn)為scroll(滑動(dòng)) container: $("#container"), // 指定對(duì)某容器中的圖片實(shí)現(xiàn)效果 failure_limit:2 //加載2張可見區(qū)域外的圖片,lazyload默認(rèn)在找到第一張不在可見區(qū)域里的圖片時(shí)則不再繼續(xù)加載,但當(dāng)HTML容器混亂的時(shí)候可能出現(xiàn)可見區(qū)域內(nèi)圖片并沒加載出來的情況 }); }); });
為了代碼可讀性,屬性值我都寫好了注釋。值得注意的是預(yù)制圖片屬性為data-original,并且最好是給予初始高寬占位,以免影響布局,當(dāng)然這里為了演示我是寫死的640x480,如果是響應(yīng)式頁面,高寬需要?jiǎng)討B(tài)計(jì)算。
echo.js方式
在前面“前端知識(shí)的一些總結(jié)”的博文中,介紹了一款非常簡單實(shí)用輕量級(jí)的圖片延時(shí)加載插件echo.js,如果你的項(xiàng)目中沒有依賴jquery,那么這將是個(gè)不錯(cuò)的選擇,50行代碼,壓縮后才1k。當(dāng)然你完全可以集成到自己項(xiàng)目中去!
下載地址:https://github.com/helijun/helijun/tree/master/plugin/echo
<style> .demo img { width: 736px; height: 490px; background: url(images/loading.gif) 50% no-repeat;} </style>
<div class="demo"> <img class="lazy" src="images/blank.gif" data-echo="images/big-1.jpg"> </div>
<script src="js/echo.min.js"></script> <script> Echo.init({ offset: 0,//離可視區(qū)域多少像素的圖片可以被加載 throttle: 0 //圖片延時(shí)多少毫秒加載 }); </script>
說明:blank.gif是一張背景圖片,包含在插件里了。圖片的寬高必須設(shè)定,當(dāng)然,可以使用外部樣式對(duì)多張圖片統(tǒng)一控制大小。data-echo指向的是真正的圖片地址。
以上是“js前端如何實(shí)現(xiàn)圖片懶加載”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。