天天看點

前端實作圖檔懶加載(lazyload)的兩種方式

在實際的項目開發中,我們通常會遇見這樣的場景:一個頁面有很多圖檔,而首屏出現的圖檔大概就一兩張,那麼我們還要一次性把所有圖檔都加載出來嗎?顯然這是愚蠢的,不僅影響頁面渲染速度,還浪費帶寬。這也就是們通常所說的首屏加載,技術上現實其中要用的技術就是圖檔懶加載--到可視區域再加載。

思路:

将頁面裡所有img屬性src屬性用data-xx代替,當頁面滾動直至此圖檔出現在可視區域時,用js取到該圖檔的data-xx的值賦給src。

關于各種寬高:

頁可見區域寬: document.body.clientWidth;
網頁可見區域高: document.body.clientHeight;
網頁可見區域寬: document.body.offsetWidth (包括邊線的寬);
網頁可見區域高: document.body.offsetHeight (包括邊線的寬);
網頁正文全文寬: document.body.scrollWidth;
網頁正文全文高: document.body.scrollHeight;
網頁被卷去的高: document.body.scrollTop;
網頁被卷去的左: document.body.scrollLeft;
網頁正文部分上: window.screenTop;
網頁正文部分左: window.screenLeft;
螢幕分辨率的高: window.screen.height;
螢幕分辨率的寬: window.screen.width;
螢幕可用工作區高度: 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="測試懶加載圖檔"/>
</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", //漸現,show(直接顯示),fadeIn(淡入),slideDown(下拉)
          threshold : 180, //預加載,在圖檔距離螢幕180px時提前載入
          event: 'click',  // 事件觸發時才加載,click(點選),mouseover(滑鼠劃過),sporty(運動的),預設為scroll(滑動)
          container: $("#container"), // 指定對某容器中的圖檔實作效果
          failure_limit:2 //加載2張可見區域外的圖檔,lazyload預設在找到第一張不在可見區域裡的圖檔時則不再繼續加載,但當HTML容器混亂的時候可能出現可見區域内圖檔并沒加載出來的情況      
        }); 
      });      
  });      

為了代碼可讀性,屬性值我都寫好了注釋。值得注意的是預制圖檔屬性為data-original,并且最好是給予初始高寬占位,以免影響布局,當然這裡為了示範我是寫死的640x480,如果是響應式頁面,高寬需要動态計算。

dome示範位址:http://h5.sztoda.cn/test/testLazyLoad

echo.js方式

在前面“前端知識的一些總結”的博文中,介紹了一款非常簡單實用輕量級的圖檔延時加載插件echo.js,如果你的項目中沒有依賴jquery,那麼這将是個不錯的選擇,50行代碼,壓縮後才1k。當然你完全可以內建到自己項目中去!

下載下傳位址: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,//離可視區域多少像素的圖檔可以被加載
   throttle: 0 //圖檔延時多少毫秒加載
}); 

</script>      

說明:blank.gif是一張背景圖檔,包含在插件裡了。圖檔的寬高必須設定,當然,可以使用外部樣式對多張圖檔統一控制大小。data-echo指向的是真正的圖檔位址。

總結:

兩者都非常簡單,實作思路是一樣的,隻是jquerylazyload多幾個屬性。其實常用的echo就足夠了,并且完全可以內建到自己項目中的公共js中,圖檔懶加載是相當常見且簡單實用的功能,如果你的項目中還是傻瓜式的一次性全部加載,那麼請花20分鐘優化下~

轉載于:https://www.cnblogs.com/liliangel/p/6122836.html

繼續閱讀