導航:首頁 > 編程語言 > js圖片的預載入

js圖片的預載入

發布時間:2025-01-28 16:18:19

javascript圖片預載入和延時載入的區別

javascript圖片預載入和延時載入的區別主要體現在圖片傳輸到客戶端的時機上,都是為了提升用戶體驗的,延時載入又叫懶載入。
兩種技術的本質:兩者的行為是相反的,一個是提前載入,一個是遲緩甚至不載入。懶載入對伺服器前端有一定的緩解壓力作用,預載入則會增加伺服器前端壓力。
預載入:提前載入圖片,當用戶需要查看時可直接從本地緩存中渲染。
實現方式: 可以用CSS(background)、js(Image)、HTML(<img />)都可以。常用的是new Image();設置其src來實現預載,再使用onload方法回調預載完成事件。只要瀏覽器把圖片下載到本地,同樣的src就會使用緩存,這是最基本也是最實用的預載方法。當Image下載完圖片頭後,會得到寬和高,因此可以在預載前得到圖片的大小(方法是用記時器輪循寬高變化)。
懶載入:主要目的是作為伺服器前端的優化,減少請求數或延遲請求數,一些圖片非常多的網站中非常有用,在瀏覽器可視區域外的圖片不會被載入,直到用戶將頁面滾動到它們所在的位置才載入,這樣對於含有很多 圖片的比較長的網頁來說,可以載入的更快,並且還能節省伺服器帶寬。,實現方式:
1.第一種是純粹的延遲載入,使用setTimeOut或setInterval進行載入延遲.
2.第二種是條件載入,符合某些條件,或觸發了某些事件才開始非同步下載。
3.jQuery插件中也有插件來實現該功能。
4.第三種是可視區載入,即僅載入用戶可以看到的區域,這個主要由監控滾動條來實現,一般會在距用戶看到某圖片前一定距離遍開始載入,這樣能保證用戶拉下時正好能看到圖片。
預載入核心代碼參考:
document.getElementById("preload-01").style.background = "url(http://expsoft.com/image-01.png) no-repeat -9999px -9999px";

img1 = new Image();img1.src = "http://expsoft.com/path/to/image-001.gif";
if (img1.complete) { ready.call(img); load && load.call(img);
callback.call(img1,img1.width, img1.height);
return; }// 直接返回,不用再處理onload事件
img1.onload = function(){ callback.call(img1,img1.width, img1.height); };
懶載入核心代碼參考:
.lazy {
display: none;
}
<img class="lazy" src="img/grey.gif" data-original="img/example.jpg" width="640" heigh="480">
必須在 DOM ready 時將佔位符顯示出來, 這可以在插件初始化的同時完成.

$("img.lazy").show().lazyload();

設置敏感度,默認情況下圖片會出現在屏幕時載入. 如果你想提前載入圖片, 可以設置 threshold 選項, 設置 threshold 為 200 令圖片在距離屏幕 200 像素時提前載入.
$("img.lazy").lazyload({ threshold : 200 });

㈡ 圖片懶載入和預載入

懶載入也叫延遲載入,指的是在長網頁中延遲載入圖像,是一種很好優化網頁性能的方式 。用戶滾動到它們之前,可視區域外的圖像不會載入。這與圖像預載入相反,在長網頁上使用延遲載入將使網頁載入更快。在某些情況下,它還可以幫助減少伺服器負載。常適用圖片很多,頁面很長的電商網站場景中。

首先將頁面上的圖片的 src 屬性設為空字元串,而圖片的真實路徑則設置在data-original屬性中, 當頁面滾動的時候需要去監聽scroll事件,在scroll事件的回調中,判斷我們的懶載入的圖片是否進入可視區域,如果圖滲配片在可視區內將圖片的 src 屬性設置為data-original 的值,這樣就可以實現延遲載入。

資源預載入是另一個性能優化技術,我們可以使用該技蘆賀術來預先告知瀏覽器某些資源可能在將來會被使用到。 預載入簡單來說就是將所有所需的資源提前請求載入到本地,這樣後面在需要用到時就直接從緩存取資源

在網頁全部載入之前,對一些主要內容進行載入,以提供給用戶更好的體驗,減少等待的時間。否則,如果一個頁面的內容過於龐大,沒有使用預載入技術的頁面就會長時間的展現為一片空白,直到所有內容載入完畢。

<img src="http://pic26.nipic.com/20121213/6168183 0044449030002.jpg" style="display:none"/>

<script src="./myPreload.js"></script>

PreloadJS提叢嘩指供了一種預載入內容的一致方式,以便在HTML應用程序中使用。預載入可以使用HTML標簽以及XHR來完成。默認情況下,PreloadJS會嘗試使用XHR載入內容,因為它提供了對進度和完成事件的更好支持,但是由於跨域問題,使用基於標記的載入可能更好。

兩者都是提高頁面性能有效的辦法, 兩者主要區別是一個是提前載入,一個是遲緩甚至不載入。懶載入對伺服器前端有一定的緩解壓力作用,預載入則會增加伺服器前端壓力

轉: https://juejin.cn/post/6844903614138286094

㈢ 關於圖片預載入的問題,高分求助

「第一執行圖片成功載入,第二次由於緩存已存在此圖片而導致圖片載入不了」,如果想解決此問題,提供一個簡便的方法:在圖片的URL後面加一個參數 img.src+"?t="+(new Date()); 即可

閱讀全文

與js圖片的預載入相關的資料

熱點內容
maya粒子表達式教程 瀏覽:84
抖音小視頻如何掛app 瀏覽:283
cad怎麼設置替補文件 瀏覽:790
win10啟動文件是空的 瀏覽:397
jk網站有哪些 瀏覽:134
學編程和3d哪個更好 瀏覽:932
win10移動硬碟文件無法打開 瀏覽:385
文件名是亂碼還刪不掉 瀏覽:643
蘋果鍵盤怎麼打開任務管理器 瀏覽:437
手機桌面文件名字大全 瀏覽:334
tplink默認無線密碼是多少 瀏覽:33
ipaddgm文件 瀏覽:99
lua語言編程用哪個平台 瀏覽:272
政采雲如何導出pdf投標文件 瀏覽:529
php獲取postjson數據 瀏覽:551
javatimetask 瀏覽:16
編程的話要什麼證件 瀏覽:94
錢脈通微信多開 瀏覽:878
中學生學編程哪個培訓機構好 瀏覽:852
榮耀路由TV設置文件共享錯誤 瀏覽:525

友情鏈接