IntersectionObserver实现滚动加载

加载模板及样式:

.template
	<div class="lazy-more" v-show="newsList.length !== 0">
	  <van-loading size="14px">您好,精彩数据准备中...</van-loading>
	</div>
.style
	.lazy-more {
	  display: flex;
	  justify-content: center;
	  padding: 10px;
	  background: #f4f4f4;
	}

在这里插入图片描述
若将此div元素放入div.v-else块内,则第一次渲染页面时无此DOM元素,第一次数据绑定完后才有此DOM元素。
将此div元素拿出div.v-else块,则第一次渲染存在此DOM元素,但骨架屏和loading加载同时存在,影响美观。
所以加上 v-show=“newsList.length !== 0” ,既存在DOM元素,避免了下面的错误,又不影响美观。

获取DOM元素:

import ref.
let loadingMore=ref(null).
return{loadingMore}.
loadingMore绑定给所监听DOM的ref属性。
  <div class="lazy-more" v-show="newsList.length !== 0" ref="loadingMore">
此时js里可以通过laodingMore.value拿到DOM元素:
	console.log(loadingMore.value)

在这里插入图片描述

Intersection Observer:

Intersection Observer API 提供了一种异步检测目标元素与祖先元素或 viewport 相交情况变化的方法。它会注册一个回调函数,每当被监视的元素进入或者退出另外一个元素时 (或者 viewport ),或者两个元素的相交部分大小发生变化时,该回调方法会被触发执行。这样,我们网站的主线程不需要再为了监听元素相交而辛苦劳作,浏览器会自行优化元素相交管理。
注意 Intersection Observer API 无法提供重叠的像素个数或者具体哪个像素重叠,他的更常见的使用方式是——当两个元素相交比例在 N% 左右时,触发回调,以执行某些逻辑。
下面这些情况都需要用到相交检测:
图片懒加载——当图片滚动到可见时才进行加载
内容无限滚动——也就是用户滚动到接近内容底部时直接加载更多,而无需用户操作翻页,给用户一种网页可以无限滚动的错觉
检测广告的曝光情况——为了计算广告收益,需要知道广告元素的曝光情况
在用户看见某个区域时执行任务或播放动画

相关文档

.script
    onMounted(() => {
      let intersectionObserver = new IntersectionObserver(async (changes) => {
        let item = changes[0];
        if (item.isIntersecting) {
          let result = await api.queryNewsBefore(
            state.newsList[state.newsList.length - 1]["date"]
          );
          state.newsList.push(Object.freeze(result));
        }
      });
      intersectionObserver.observe(loadingMore.value);
    });

在这里插入图片描述

错误:Uncaught (in promise) TypeError: Failed to execute 'observe' on 'IntersectionObserver': parameter 1 is not of type 'Element'.

实际上,因为 document.querySelector 如果元素不存在就会返回 null ,而当 element 传递给 sectionObserver.observe() 时,如果 element 是 null ,就会抛出上述异常发生 Failed to execute ‘observe’ on ‘IntersectionObserver’: parameter 1 is not of type ‘Element’ ,所以请确保 document.querySelector 选择的元素必须存在。
解决链接

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
IntersectionObserver是一种新的API,可以用于实现加载。懒加载是指在页面滚动时,只加载可视区域内的内容,而不是一次性加载所有内容。这样可以优化网页加载速度,提升用户体验。 下面是IntersectionObserver实现加载的步骤: 1. 创建一个IntersectionObserver对象:可以通过其构造函数创建。 2. 选取需要进行懒加载的图片或其他DOM元素,将其包裹在一个容器元素中。 3. 使用IntersectionObserver对象的observe方法来观察容器元素。 4. 在回调函数中获取到可见性变化的元素,如果元素进入可视区域,就将其src属性指向真实图片的地址,实现图片的懒加载。 下面是一个示例代码: ``` let lazyImages = document.querySelectorAll('.lazy-image'); let options = { root: null, // 窗口视图作为根元素 rootMargin: '0px', // 不添加边框 threshold: 0.1 // 当可见性达到10%时触发回调 }; let observer = new IntersectionObserver(function(entries, observer) { entries.forEach(entry => { if (entry.isIntersecting) { // 元素进入可见视图 let lazyImage = entry.target; lazyImage.src = lazyImage.dataset.src; observer.unobserve(lazyImage); // 取消观察 } }); }, options); lazyImages.forEach(lazyImage => { observer.observe(lazyImage); }); ``` 在上面的代码中,我们首先选取了所有带有lazy-image类的图片元素,然后创建了一个IntersectionObserver对象,指定了观察的根元素和触发回调的阈值。接着,我们遍历了所有图片元素,使用observe方法观察了每个元素。在回调函数中,我们判断元素是否进入了可视区域,如果是,就将该元素的data-src属性值赋给src属性,实现加载,然后取消对该元素的观察。最后,我们通过forEach方法将所有图片元素添加到IntersectionObserver的观察列表中。 注意,容器元素的宽高需要在CSS中指定,否则IntersectionObserver无法准确计算元素的可见性。同样,图片元素的真实地址需要通过data-src属性指定,而不是src属性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值