搭建
把IntersectionObserver 图片懒加载设置成一个指令(v-lazy)
src/components/library/index.js
// 导入组件
import XtxSkeleton from '@/components/library/xtx-skeleton'
import XtxCarousel from '@/components/library/xtx-carousel'
import XtxMore from '@/components/library/xtx-more'
import defaultImg from '@/assets/images/200.png'
// vue3插件写法:导出一个对象,有install函数,默认传入app构造函数,Vue基础之上扩展
export default {
install (app) {
// 在app上进行扩展,app提高component directive
// 如果要挂载原型 app.config.globalProperties.$http
// 设置全局组件
app.component(XtxSkeleton.name, XtxSkeleton)
app.component(XtxCarousel.name, XtxCarousel)
app.component(XtxMore.name, XtxMore)
// 定义指令
defineDirective(app)
}
}
// 定义指令
const defineDirective = app => {
// 图片懒加载指令
// 原理:先存储图片地址不能在src上,当图片进入可视区,将存储的图片地址设置给图片元素即可
app.directive('lazy', {
// vue2 监听使用指令的DOM是否创建好,钩子函数:inserted
// vue3 的指令拥有的钩子函数和组件的一样,使用指令的DOM是否创建好,钩子函数:mounted
mounted (el, binding) {
// 创建一个观察对象 用来观察使用当前元素的指令
const observe = new IntersectionObserver(([{ isIntersecting }]) => {
// 进入可视区
if (isIntersecting) {
// 停止观察
observe.unobserve(el)
// 把指令的值设置给el的src属性 binding.value就是指令的值
// 处理图片加载失败 error 图片加载失败 load 图片加载成功
el.onerror = () => {
// 加载失败设置默认图片
el.src = defaultImg
}
el.src = binding.value
}
}, {
threshold: 0
})
// 开启观察
observe.observe(el)
}
})
}
main.js
// 导入自己的全局组件库
import UI from '@/components/library'
// use(UI)
createApp(App).use(UI).mount('#app')
使用
// 与正常的写法区别
// 使用src
<img src="http://img.com/img.png" alt="">
// 使用v-lazy
<img v-lazy="http://img.com/img.png" alt="">
方法
-
使
IntersectionObserver
对象停止监听工作。 -
使
IntersectionObserver
开始监听一个目标元素。 -
返回所有观察目标的
IntersectionObserverEntry
对象数组。 -
使
IntersectionObserver
停止监听特定目标元素。
批量注册全局组件
点击标题跳转