组件数据懒加载
我们可以使用 @vueuse/core 中的 useIntersectionObserver 来实现监听进入可视区域行为,但是必须配合vue3.0的组合API的方式才能实现。
大致步骤:
- 理解 useIntersectionObserver 的使用,各个参数的含义
- 改造 组件成为数据懒加载,掌握 useIntersectionObserver 函数的用法
- 封装 useLazyData 函数,作为数据懒加载公用函数
- 使用懒加载方式
先分析下这个useIntersectionObserver 函数:
// stop 是停止观察是否进入或移出可视区域的行为
const {
stop } = useIntersectionObserver(
// target 是观察的目标dom容器,必须是dom容器,而且是vue3.0方式绑定的dom对象
target,
// isIntersecting 是否进入可视区域,true是进入 false是移出
// observerElement 被观察的dom
([{
isIntersecting }], observerElement) => {