網(wǎng)站前端制作之圖片懶加載的功能介紹

2023-02-13    分類: 網(wǎng)站建設(shè)

在一次項(xiàng)目中需要做一個電子書,然后再網(wǎng)上找了一個電子書的模板,但是我所做的項(xiàng)目時電子版的圖刊,需要加載有很多圖片,當(dāng)完成后上傳了100多張圖片,這個時候發(fā)現(xiàn)加載非常的慢 ,效果要很久才出來,這是我就想到了我以前一個項(xiàng)目當(dāng)時也是因?yàn)榫W(wǎng)站首頁圖片太大太多,js插件也多導(dǎo)致首頁打開速度奇慢無比 ,后來用圖片懶加載稍微優(yōu)化了一下發(fā)現(xiàn)效果還不錯,當(dāng)時是打算用jquery.lazyload.js 去做的,試了半天都發(fā)現(xiàn)沒有效果于是就自己寫了一個簡單的圖片的懶加載。
思路跟網(wǎng)上大家說的差不多,就是在img標(biāo)簽上放一張臨時圖片 然后定義一個data-img 的屬性,然后自己更具網(wǎng)站的實(shí)際需求寫 替換圖片的事件, 我這里是電子書 做的點(diǎn)擊事件。

前端制作1

前端制作2

$('#next_page_button').click(function() {
var dong_num= $(this).data('num');
var all_num = dong_num+5;
$(this).data('num',all_num);
$('.lazy').each(function() {
var $img = $(this);
var img_num = $img.data('num');
if (img_num <= all_num) {
var dong_num = $img.data('img');
$img.attr('src',dong_num);
}
});
});
這里是想法是第一次加載只展示5張 然后沒觸發(fā)一次事件就去判斷當(dāng)前的data-num值, 提前加載5張,把num的值小于當(dāng)前數(shù)值num的img標(biāo)簽內(nèi)的默認(rèn)圖片都替換為需要展示的圖片。然后把點(diǎn)擊事件上的num值改成當(dāng)前判斷的值,做好下次事件的數(shù)值判斷。這是一個簡單例子,希望能給你們一些解決問題靈感。
當(dāng)然如果網(wǎng)站的布局有規(guī)律也可以嘗試使用jquery.lazyload.js
分享一個lazyload.js詳解
https://www.cnblogs.com/yzg1/p/5051554.html
lazyload.js下載地址是github上的

文章題目:網(wǎng)站前端制作之圖片懶加載的功能介紹
網(wǎng)頁鏈接:http://www.muchs.cn/news24/236774.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供ChatGPT、網(wǎng)頁設(shè)計(jì)公司外貿(mào)建站、網(wǎng)站維護(hù)關(guān)鍵詞優(yōu)化、網(wǎng)站設(shè)計(jì)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作