vue3組合式api實(shí)現(xiàn)v-lazy圖片懶加載的方法實(shí)例
前置知識(shí)
Intersection Observer
瀏覽器提供api,用于檢測目標(biāo)元素和祖先元素/頂級(jí)文檔視窗 (viewport) 交叉狀態(tài)的方法。
const observer = new IntersectionObserver(function (IntersectionObserverEntry) {},options); observer.observe(el);
構(gòu)造函數(shù)接收一個(gè)回調(diào)函數(shù),一個(gè)配置對象(可選),返回一個(gè)觀察器實(shí)例。實(shí)例的observe方法接收一個(gè)dom節(jié)點(diǎn)作為觀察的對象
當(dāng)目標(biāo)對象出現(xiàn)在視口的時(shí)候,會(huì)調(diào)用回調(diào)函數(shù),傳遞一個(gè)元素都為IntersectionObserverEntry
對象的數(shù)組。
IntersectionObserverEntry
對象有以下屬性 (只列舉了這篇用到的兩個(gè)):
- target:被觀察的目標(biāo)元素,是一個(gè) DOM 節(jié)點(diǎn)對象
- intersectionRatio:目標(biāo)元素的可見比例,即intersectionRect占boundingClientRect的比例,完全可見時(shí)為1,完全不可見時(shí)小于等于0
Vue3指令周期
- created:在綁定元素的 attribute 或事件監(jiān)聽器被應(yīng)用之前調(diào)用;
- beforeMount:當(dāng)指令第一次綁定到元素并且在掛載父組件之前調(diào)用;
- mounted:在綁定元素的父組件被掛載后調(diào)用;
- beforeUpdate:在更新包含組件的 VNode 之前調(diào)用;
- updated:在包含組件的 VNode 及其子組件的 VNode 更新后調(diào)用;
- beforeUnmount:在卸載綁定元素的父組件之前調(diào)用;
- unmounted:當(dāng)指令與元素解除綁定且父組件已卸載時(shí),只調(diào)用一次;
image對象
Image 對象代表嵌入的圖像。
- onload 當(dāng)圖像裝載完畢時(shí)調(diào)用的回調(diào)函數(shù)。
思路
想要的效果 在有多個(gè)圖片加載的時(shí)候 只要在最外面的wrapper上用一次v-lazy就可以
每張圖片的src先用加載gif替換掉,然后再放到文檔碎片里面,等到用戶滑動(dòng)到視口了再掛載上圖片元素,之前一直使用加載的gif占位,等圖片加載完成再替換。
首先vue3的指令跟組件類似也有生命周期,created
的時(shí)候指令綁定的dom元素還沒有attribute,也沒有DOM結(jié)構(gòu),所以不適合,mounted
整個(gè)DOM元素已經(jīng)掛載到頁面上了,圖片在掛載上去的時(shí)候就開始加載,再做懶加載已經(jīng)沒有意義了,所以使用beforeMount
,有完整的DOM結(jié)構(gòu),但是沒有掛載到頁面上。
完整代碼
export const lazyLoad = { beforeMount(el: any, binding: any, vnode: any, prevVnode: any) { const img = el.querySelector(`.${el.className} img`); const src = img.getAttribute("src"); // 圖片使用loading gif替換 img.setAttribute("src", "https://m.tea7.com/images/imgLoading.gif"); // 新建Image對象 const tempImg = new Image(); tempImg.onload = function () { img.setAttribute("src", src); }; const parent = img.parentNode; const observer = new IntersectionObserver(function (changes) { // 可視 changes.forEach((item) => { if (item.intersectionRatio !== 0) { tempImg.src = src; } }); }); observer.observe(el); }, };
參考鏈接:
總結(jié)
到此這篇關(guān)于vue3組合式api實(shí)現(xiàn)v-lazy圖片懶加載的文章就介紹到這了,更多相關(guān)vue3實(shí)現(xiàn)v-lazy圖片懶加載內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue項(xiàng)目運(yùn)行或打包時(shí),頻繁內(nèi)存溢出情況問題
這篇文章主要介紹了vue項(xiàng)目運(yùn)行或打包時(shí),頻繁內(nèi)存溢出情況的解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04vue 解決在微信內(nèi)置瀏覽器中調(diào)用支付寶支付的情況
這篇文章主要介紹了vue 解決在微信內(nèi)置瀏覽器中調(diào)用支付寶支付的情況,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11element中el-autocomplete的常見用法示例
這篇文章主要給大家介紹了關(guān)于element中el-autocomplete的常見用法的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用element具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2023-03-03Vue Element前端應(yīng)用開發(fā)之組織機(jī)構(gòu)和角色管理
本篇文章繼續(xù)深化Vue Element權(quán)限管理模塊管理的內(nèi)容,介紹組織機(jī)構(gòu)和角色管理模塊的處理,使得我們了解界面組件化模塊的開發(fā)思路和做法,提高我們界面設(shè)計(jì)的技巧,并減少代碼的復(fù)雜性,提高界面代碼的可讀性,同時(shí)也是利用組件的復(fù)用管理。2021-05-05關(guān)于el-table-column的formatter的使用及說明
這篇文章主要介紹了關(guān)于el-table-column的formatter的使用及說明,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10Vue實(shí)現(xiàn)動(dòng)態(tài)查詢規(guī)則生成組件
今天我們來給大家介紹下在Vue開發(fā)中我們經(jīng)常會(huì)碰到的一種需求場景,本文主要介紹了Vue動(dòng)態(tài)查詢規(guī)則生成組件,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05