【vuejs插件】vue中使用图片懒加载vue-lazyload插件详细指南

29

在vue中使用图片懒加载详细指南

说明

当网络请求比较慢的时候,提前给这张图片添加一个像素比较低的占位图片,不至于堆叠在一块,或显示大片空白,让用户体验更好一点。

使用方式

使用vue的 vue-lazyload 插件
插件地址:

https://www.npmjs.com/package/vue-lazyload

案例

demo: 懒加载案例demo

Installation 安装方式

npm


$ npm i vue-lazyload -D

CDN

CDN: https://unpkg.com/vue-lazyload/vue-lazyload.js

<script src="https://unpkg.com/vue-lazyload/vue-lazyload.js"></script>
<script>
  Vue.use(VueLazyload)
  ...
</script>

用法

main.js 在入口文件


import Vue from 'vue'
import App from './App.vue'
import VueLazyload from 'vue-lazyload'  //引入这个懒加载插件

Vue.use(VueLazyload)

// 或者添加VueLazyload 选项
Vue.use(VueLazyload, {
  preLoad: 1.3,
  error: 'dist/error.png',
  loading: 'dist/loading.gif',
  attempt: 1
})

new Vue({
  el: 'body',
  components: {
    App
  }
})

在入口文件添加后,在组件任何地方都可以直接使用把 img 里的:src -> v-lazy

 <div class="pic">
    <a href="#"><img :src="'/static/img/' + item.productImage" alt=""></a>
</div>

把之前项目中img 标签里面的 :src 属性 改成 v-lazy 
 <div class="pic">
    <a href="#"><img v-lazy="'/static/img/' + item.productImage" alt=""></a>
</div>

参数选项说明

key description default options
preLoad proportion of pre-loading height 1.3 Number
error 当加载图片失败的时候 'data-src' String
loading 当加载图片成功的时候 'data-src' String
attempt 尝试计数 3 Number
listenEvents 想要监听的事件 ['scroll', 'wheel', 'mousewheel', 'resize', 'animationend', 'transitionend', 'touchmove'] Desired Listen Events
adapter 动态修改元素属性 { } Element Adapter
filter 图片监听或过滤器 { } Image listener filter
lazyComponent lazyload component false Lazy Component
dispatchEvent 触发dom事件 false Boolean
throttleWait throttle wait 200 Number
observer use IntersectionObserver false Boolean
observerOptions IntersectionObserver options { rootMargin: '0px', threshold: 0.1 } IntersectionObserver

想要监听的事件

您可以通过传递数组来配置想要使用vue - lazyload的事件
监听器的名字。

Vue.use(VueLazyload, {
  preLoad: 1.3,
  error: 'dist/error.png',
  loading: 'dist/loading.gif',
  attempt: 1,
  // the default is ['scroll', 'wheel', 'mousewheel', 'resize', 'animationend', 'transitionend']
  listenEvents: [ 'scroll' ]
})

如果您遇到这个插件重新设置加载的麻烦,这是很有用的
当你有某些动画和过渡的时候。


如果觉得我的文章对你有用,请随意赞赏

你可能感兴趣的

18 条评论
国生_ · 2018-02-06

如果页面的内容是后台回来的HTML标签,又该如何去使用呢?

+1 回复

0

请问这个问题解决了吗,因为现在html 一部分是后台返回的

永恒的爱 · 9月20日
小斌哥 · 2017-10-25

这个好用吗

回复

汪大大坚 · 2017-12-14

如果页面上需要几个不同的默认图怎么办,这里貌似是统一用一张默认图

回复

0

我也想要知道这个怎么解决的

好先森_光芒四射 · 2018-01-16
0

这个也是我想知道的

南心之 · 2018-02-07
0

<div v-lazy-container="{ selector: 'img' }">
<img data-src="//domain.com/img1.jpg" data-error="xxx.jpg">
<img data-src="//domain.com/img2.jpg" data-loading="xxx.jpg">
<img data-src="//domain.com/img3.jpg">
</div>

LittleChell · 2018-04-10
陈小萌 · 2018-03-14

有没有加载完成后的回调

回复

0

直接可以图片load

Benbzhou · 2018-07-28
fftu · 2018-04-27

参数选项说明表格中loading项的说明错了。
官方文档:src of the image while loading。加载时的url

回复

iiiiiiiii · 2018-05-05

图片过渡效果怎么加上去,

回复

0

刚才在这个帖子中分享了方法,仅供参考:https://segmentfault.com/q/10...

艺灵 · 6月29日
艺灵 · 6月29日

如果使用@1.3.0版本,图片懒加载会失败(至少当前版本暂未修复)!详情见:https://segmentfault.com/a/11... ,正在使用的看官需要注意一下下~

回复

即使是错误 · 8月12日

如何实现类似微信朋友圈 不同尺寸图片显示对应尺寸的占位图

回复

zhouciming · 8月23日

只会加载一张图,有没有完整的demo呢,感谢!

回复

载入中...