vue圖片懶加載代碼實現(xiàn)
1、首先解釋一下什么叫圖片懶加載:
我們使用軟件的時候,會有很多圖片需要加載,但是當(dāng)網(wǎng)絡(luò)環(huán)境不好,或內(nèi)存不足的情況,就會導(dǎo)致用戶首屏加載特別慢,影響用戶體驗,所以為了解決這個問題,提出了圖片懶加載的方法來解決該問題。
2、解決思路:
①當(dāng)圖片區(qū)域到達用戶界面可視區(qū)域的時候才進行加載圖片
②首屏加載時候img標簽src賦為空值,這樣就不會去渲染看不見的圖片而浪費時間
③當(dāng)用戶滑動到圖片的可視區(qū)域后,替換src的路徑,改為正式路徑,則開始渲染圖片
3、好處:
這樣做的好處就是可以使用當(dāng)前網(wǎng)絡(luò)環(huán)境來全力加載該可視區(qū)域的圖片,增加加載速度;在圖片沒有到達可視區(qū)域的時候不會加載,避免浪費性能
4、代碼實現(xiàn)(vue2):
① test.vue 文件
<template> <div class="app"> <div class="top">fjdskla</div> <div><img v-lazy src="../static/image/left.jpg" alt="img" /></div> <div><img v-lazy src="../static/image/left.png" alt="img" /></div> <div><img v-lazy src="../static/image/left.jpg" alt="img" /></div> <div><img v-lazy src="../static/image/left.png" alt="img" /></div> </div> </template> <script> export default { data() { return {} }, created() {}, mounted() {}, methods: {}, } </script> <style scoped lang="scss"> .app { .top { height: 2000px; width: 100%; background-color: beige; } div { margin-top: 50px; } } </style>
② main.js 設(shè)置全局自定義指令 命名為 lazy
// 定義懶加載圖片或者文件等,自定義指令 Vue.directive('lazy', (el, binding) => { let oldSrc = el.src //保存舊的src,方便后期渲染時候賦值src真實路徑 el.src = "" //將渲染的src賦為空,則不會渲染圖片出來 let observer = new IntersectionObserver(([{ isIntersecting }]) => { // 調(diào)用方法得到該elDOM元素是否處于可視區(qū)域 if (isIntersecting) { //回調(diào)是否處于可視區(qū)域,true or false el.src = oldSrc //如果處于可視區(qū)域額,將最開始保存的真實路徑賦予DOM元素渲染 observer.unobserve(el) // 只需要監(jiān)聽一次即可,第二次滑動到可視區(qū)域時候不在監(jiān)聽 } }) observer.observe(el) // 調(diào)用方法 })
5、弊端
IntersectionObserver 方法可能沒有兼容全瀏覽器,如果要實現(xiàn)兼容全瀏覽器,可以引入對應(yīng)的插件實現(xiàn)
總結(jié)
到此這篇關(guān)于vue圖片懶加載代碼實現(xiàn)的文章就介紹到這了,更多相關(guān)vue圖片懶加載內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue實現(xiàn)echart餅圖legend顯示百分比的方法
本文主要介紹了vue實現(xiàn)echart餅圖legend顯示百分比的方法,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-09-09詳解在Vue中如何使用axios跨域訪問數(shù)據(jù)
本篇文章主要介紹了在Vue中如何使用axios跨域訪問數(shù)據(jù),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07vue css 引入asstes中的圖片無法顯示的四種解決方法
這篇文章主要介紹了vue css 引入asstes中的圖片 無法顯示的幾種解決方案,本文給出了四種解決方法,每種方法給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-03-03vue子組件封裝彈框只能執(zhí)行一次的mounted問題及解決
這篇文章主要介紹了vue子組件封裝彈框只能執(zhí)行一次的mounted問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03