中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

js前端如何實現圖片懶加載

發布時間:2021-07-06 14:11:24 來源:億速云 閱讀:190 作者:小新 欄目:web開發

這篇文章主要介紹js前端如何實現圖片懶加載,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

思路:

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

關于各種寬高:

  1. 頁可見區域寬: document.body.clientWidth;

  2. 網頁可見區域高: document.body.clientHeight;

  3. 網頁可見區域寬: document.body.offsetWidth (包括邊線的寬);

  4. 網頁可見區域高: document.body.offsetHeight (包括邊線的寬);

  5. 網頁正文全文寬: document.body.scrollWidth;

  6. 網頁正文全文高: document.body.scrollHeight;

  7. 網頁被卷去的高: document.body.scrollTop;

  8. 網頁被卷去的左: document.body.scrollLeft;

  9. 網頁正文部分上: window.screenTop;

  10. 網頁正文部分左: window.screenLeft;

  11. 屏幕分辨率的高: window.screen.height;

  12. 屏幕分辨率的寬: window.screen.width;

  13. 屏幕可用工作區高度: 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,如果是響應式頁面,高寬需要動態計算。

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指向的是真正的圖片地址。

以上是“js前端如何實現圖片懶加載”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

睢宁县| 长春市| 天峨县| 霍山县| 钦州市| 会理县| 沙坪坝区| 民勤县| 北流市| 平阳县| 扎兰屯市| 皋兰县| 保山市| 寿阳县| 平潭县| 武隆县| 万源市| 大安市| 纳雍县| 高雄市| 门头沟区| 吉林省| 高清| 景泰县| 绥阳县| 黄石市| 宁波市| 霸州市| 庆城县| 义马市| 呼图壁县| 轮台县| 郎溪县| 乌恰县| 山东省| 托克托县| 富宁县| 梨树县| 洛阳市| 中西区| 阿拉善盟|