vue 圖片懶加載(以及踩過的坑)


一個頁面圖片比較多的時候,需要對界面的圖片進行懶加載處理,今天遇到了,做個懶加載的筆記。

1,需要安裝vue的懶加載插件。

npm install vue-lazyload --save-dev

2,需要在main.js里面進行引用。

import VueLazyload from "vue-lazyload";

Vue.use(VueLazyload);

或者自定義

Vue.use(VueLazyload, {
preLoad: 1.3,
error: 'dist/error.png',
loading: 'dist/loading.gif',
attempt: 1
})

3,修改圖片的路徑,設置為懶加載的形式,將src改成v-lazy

 <img v-lazy="psdimg" class="psd" />

 

     今天踩過的坑總結。

     當遇到是v-for循環的時候,或者用div包裹着img的時候,需要在div上面添加v-lazy-container="{ selector: 'img' }"

<div v-lazy-container="{ selector: 'img' }">
  <img data-src="//domain.com/img1.jpg">
  <img data-src="//domain.com/img2.jpg">
  <img data-src="//domain.com/img3.jpg">  
</div>
 
或者這種:
 <div>
v-lazy-container="{ selector: 'img' }"
class="contentDiv construction"
v-html="content">
</div>
 
 

以及我將html里面的圖片路徑拿到后,轉換成懶加載的時候,

 

 

 一定是 data-src,而不是v-lazy,要不然在接口獲取的時候,拿到了圖片地址,但是會一直顯示不出來的。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM