原生js實現圖片懶載入+加入節流

来源:https://www.cnblogs.com/zglin/archive/2019/08/08/11320649.html
-Advertisement-
Play Games

這兩天在學習圖片的懶載入實現,看了很多大佬的博客,終於有了點成果。現在用了其中一位大佬的文章中的代碼實現了圖片懶載入並且在其基礎上加入了節流函數。 原理就不多講了,有需要的可以去大佬的文章看看。大佬文章可以從這裡進->(https://www.jianshu.com/p/9b30b03f56c2)。 ...


這兩天在學習圖片的懶載入實現,看了很多大佬的博客,終於有了點成果。現在用了其中一位大佬的文章中的代碼實現了圖片懶載入並且在其基礎上加入了節流函數。

原理就不多講了,有需要的可以去大佬的文章看看。大佬文章可以從這裡進->(https://www.jianshu.com/p/9b30b03f56c2)。

先上HTML結構:

1     <div></div>
2     <img src="" id="i1" data-src="image1">
3     <div></div>
4     <img src="" id="i2" alt="" data-src="image2">

然後是樣式:

 1 <style>
 2         * {
 3             padding: 0;
 4             margin: 0;
 5         }
 6 
 7         div {
 8             height: 2000px;
 9         }
10 
11         #i1 {
12             display: block;
13             width: 200px;
14             height: 200px;
15             background-color: red;
16         }
17 
18         #i2 {
19             display: block;
20             width: 200px;
21             height: 200px;
22             background-color: green;
23         }
24     </style>

最後是JavaScript的代碼:

 1 <script>
 2         var lastTime = new Date().getTime();
 3         function lazyLoad() {
 4             //放入節流函數前的準備工作
 5             function preWork() {
 6                 //獲取頁面圖片標簽
 7                 var imgs = document.querySelectorAll("img");
 8                 //可視區高度
 9                 var h = window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight;
10 
11                 [].forEach.call(imgs,function (img) {
12                     //判斷data-src屬性是否存在,不存在代表圖片已經載入過
13                     if (!img.getAttribute('data-src')) {
14                         return;
15                     }
16                     //判斷高度差,替換路徑後移除data-src屬性
17                     if (img.getBoundingClientRect().top < h) {
18                         img.src = img.getAttribute('data-src');
19                         img.removeAttribute('data-src');
20                     }
21                 });
22 
23                 //利用與運算,如果與前面為false,則不運行後面的語句;若為true,繼續運行後面的語句。從而達到路徑替換完後可以執行移除監聽事件的效果
24                 [].every.call(imgs, function (img) {
25                     return !img.getAttribute('data-src');
26                 }) && (window.removeEventListener("scroll", lazyLoad));
27             }
28 
29             //節流函數
30             function throttle() {
31                 var nowTime = new Date().getTime();
32                 if (nowTime - lastTime > 1000) {
33                     preWork();
34                     console.log("節流執行");
35                     lastTime = nowTime;
36                 }
37 
38             }
39 
40             //執行節流函數
41             throttle();
42         }
43 
44         window.addEventListener("scroll", lazyLoad);
45         window.addEventListener("load", lazyLoad);
46 
47     </script>

js的代碼裡面加了一些註釋,希望能幫助大家理解。

本人是前端小菜鳥一枚,代碼里如果出現錯誤希望大家多多包涵併在評論區提出,本人會認真改正的!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 寫在前面:前面的內容記錄了JavaScript的一些基本概念,本次主要講解一下JS中常用的語句。 和大多數其他編程語言一樣,JS也主要包括:選擇、迴圈、錯誤檢測、函數等。JS的語句基本是由值、運算符、表達式、關鍵字和註釋構成,但並不是語句一定包含所有以上要素。 電腦程式一般是指能夠被電腦執行的一 ...
  • swiper一款非常好用的輪播插件,支持移動端和PC端,用過很多次了,這次簡單的總結一下。方便以後查找使用,說明一下,下麵的例子是基於swiper 4.0+版本的,如果你是其他的版本,請自行前往官網查看 至於為什麼使用swiper,而不是自己手寫,請看下麵官網的截圖: 開個玩笑,說白了,就是這個確實 ...
  • /** * 對於由簡單類型數據組成的對象為元素組成的數組進行去重操作 * @params {Array} 需要去重的對象數組 * @returns {Array} 去重後的對象數組 */ function distinct(sourceArray) { var resultArray = []; v ...
  • 上一篇講了字元串的解析過程,這一篇來講講標識符(IDENTIFIER)的解析。 先上知識點,標識符的掃描分為快解析和慢解析,一旦出現Ascii編碼大於127的字元或者轉義字元,會進入慢解析,略微影響性能,所以最好不要用中文、特殊字元來做變數名(不過現在代碼壓縮後基本不會有這種情況了)。 每一位Jav ...
  • HTML特殊轉義字元列表 最常用的字元實體Character Entities 顯示說明實體名稱實體編號 半方大的空白 &ensp; &#8194; 全方大的空白 &emsp; &#8195; 不斷行的空白格 &nbsp; &#160; < 小於 &lt; &#60; > 大於 &gt; &#62; ...
  • 什麼是組件? 組件的出現,就是為了拆分Vue實例的代碼量的,能夠讓我們以不同的組件,來劃分不同的功能模塊,將來我們需要什麼樣的功能,就可以去調用對應的組件就可以了。 組件化和模塊化的區別 模塊化:是從代碼邏輯的角度進行劃分的,方便代碼分層開發,保證每個模塊功能的職能單一。例如:NodeJS 組件化: ...
  • window.onload=function(){ var a = $("#div").width(),//width()返回元素的寬高,不包括padding/border/margin b = $("#div").innerWidth(),//innerWidth()返回元素的寬高 + paddi ...
  • ajax是非同步請求技術,可以實現頁面的局部刷新。但是今天寫代碼的時候發現每次ajax之後都會發生整個頁面的刷新,最後發現這是因為觸發ajax事件的input標簽的type設置為了submit,所以會產生表單提交操作,使頁面刷新。 將type設置為button後即可正常運行。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...