背景
最近项目中,开发一个小程序列表页,PM大大给我提了一个埋点需求,列表中的每一项,出现在屏幕中的时候,需要上报一条记录。
目标
如图中操作,要依次上报 item 1 - item7,但是上滑的时候,不再重复上报
怎么做
接到需求的第一感觉是,我难道要监听页面滚动,然后通过offsetTop 去算吗!!!??? 这样显然不是最高效的。于是我去翻了一下微信的开发文档,发现有一个IntersectionObserver 的API,正好满足我的需求。
首先我们需要创建一个 IntersectionObserver wx.createIntersectionObserver(Object component, Object options)
IntersectionObserver
一共有四个方法
- IntersectionObserver.relativeTo 使用选择器指定一个节点,作为参照区域之一。
- IntersectionObserver.relativeToViewport(Object margins) 指定页面显示区域作为参照区域之一
- IntersectionObserver.observeCallback callback) 指定目标节点并开始监听相交状态变化情况
- IntersectionObserver.disconnect()
- 停止监听。回调函数将不再触发
我们这里的参照物是屏幕,所以我们使用 IntersectionObserver.relativeToViewport
来制定我们的参照物,并制定相较规则
Page({ data: { list: [ { value: 1, hadReport: false }, { value: 2, hadReport: false }, { value: 3, hadReport: false }, { value: 4, hadReport: false }, { value: 5, hadReport: false }, { value: 6, hadReport: false }, { value: 7, hadReport: false }, { value: 8, hadReport: false }, { value: 9, hadReport: false }, ] }, onLoad() { this._observer = this.createIntersectionObserver({ observeAll: true }) this._observer.relativeToViewport({ bottom: 0 }) .observe('.item', (res) => { const { index } = res.dataset; if (!this.data.list[index].hadReport) { console.log(`report ${index}`) this.data.list[index].hadReport = true; this.setData({ list: [].concat(this.data.list)}) } }) }, onUnload() { if (this._observer) this._observer.disconnect() } })
最后实现的效果如下
结论
- 类似这样的埋点,我们以后可以采用监听dom的方式去做,而不是一昧的只想着监听滚动计算位置。
- 除了可以做埋点上报,这种监听的方式,还是很适合去做一些图片懒加载等一系列操作。
联想
上述的所有操作,都是基于微信小程序去做的,那么浏览器有没有相应的API呢?
浏览器是有相应的API的, Intersection Observer API ,具体的用法与上述的用法类似。
var options = { rootMargin: '0px', threshold: 1.0 } var observer = new IntersectionObserver((...args) => { console.log(args); }, options); observer.observe(document.querySelector('.item'));
注意这个会监测dom元素的可见性变化,也就是说当dom出现在视窗的时候会触发回调,消失在视窗的时候也会触发回调
但是浏览器的 IntersectionObserver
属性兼容性一般,如果想要在浏览器做曝光或者懒加载可以考虑采用原始的方法,监听浏览器滚动,并计算dom的offsetTop,可以参考笔者很久前写的 图片延时 加载原理 及应用
参考文档
谈谈IntersectionObserver懒加载
微信小程序IntersectionObserver 文档
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
微信小程序列表埋点,小程序埋点
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- 潘安邦《思念精选集全纪录》5CD[WAV+CUE]
- 杨千嬅《千嬅新唱金牌金曲》金牌娱乐 [WAV+CUE][985M]
- 杨钰莹《依然情深》首版[WAV+CUE][1G]
- 第五街的士高《印度激情版》3CD [WAV+CUE][2.4G]
- 三国志8重制版哪个武将智力高 三国志8重制版智力武将排行一览
- 三国志8重制版哪个武将好 三国志8重制版武将排行一览
- 三国志8重制版武将图像怎么保存 三国志8重制版武将图像设置方法
- 何方.1990-我不是那种人【林杰唱片】【WAV+CUE】
- 张惠妹.1999-妹力新世纪2CD【丰华】【WAV+CUE】
- 邓丽欣.2006-FANTASY【金牌大风】【WAV+CUE】
- 饭制《黑神话》蜘蛛四妹手办
- 《燕云十六声》回应跑路:年内公测版本完成95%
- 网友发现国内版《双城之战》第二季有删减:亲亲环节没了!
- 邓丽君2024-《漫步人生路》头版限量编号MQA-UHQCD[WAV+CUE]
- SergeProkofievplaysProkofiev[Dutton][FLAC+CUE]