浅谈微信小程序列表埋点曝光指南


Posted in Javascript onOctober 15, 2019

背景

最近项目中,开发一个小程序列表页,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()
 }
})

最后实现的效果如下

浅谈微信小程序列表埋点曝光指南 

结论

  1. 类似这样的埋点,我们以后可以采用监听dom的方式去做,而不是一昧的只想着监听滚动计算位置。
  2. 除了可以做埋点上报,这种监听的方式,还是很适合去做一些图片懒加载等一系列操作。

 联想

上述的所有操作,都是基于微信小程序去做的,那么浏览器有没有相应的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 文档

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery移除button的inline onclick事件(已测试及兼容浏览器)
Jan 25 Javascript
Javascript 按位与赋值运算符 (&=)使用介绍
Feb 04 Javascript
jquery实现简单的自动播放幻灯片效果
Jun 13 Javascript
JavaScript观察者模式(经典)
Dec 09 Javascript
jQuery插件实现适用于移动端的地址选择器
Feb 18 Javascript
bootstrap中的 form表单属性role="form"的作用详解
Jan 20 Javascript
js实现鼠标左右移动,图片也跟着移动效果
Jan 25 Javascript
element-ui 时间选择器限制范围的实现(随动)
Jan 09 Javascript
微信小程序select下拉框实现效果
May 15 Javascript
微信小程序iBeacon测距及稳定程序的实现解析
Jul 31 Javascript
微信小程序自定义弹出层效果
May 26 Javascript
Axios代理配置及封装响应拦截处理方式
Apr 07 Vue.js
javascript网页随机点名实现过程解析
Oct 15 #Javascript
javascript随机变色实例代码
Oct 15 #Javascript
vue中axios的二次封装实例讲解
Oct 14 #Javascript
Vue项目打包部署到iis服务器的配置方法
Oct 14 #Javascript
浅析微信小程序modal弹窗关闭默认会执行cancel问题
Oct 14 #Javascript
vue实现百度语音合成的实例讲解
Oct 14 #Javascript
vue中进行微博分享的实例讲解
Oct 14 #Javascript
You might like
VPS中使用LNMP安装WordPress教程
2014/12/28 PHP
php实现将wav文件转换成图像文件并在页面中显示的方法
2015/04/21 PHP
如何使用PHP给图片加水印
2016/10/12 PHP
基于php数组中的索引数组和关联数组详解
2018/03/12 PHP
javascript编程起步(第四课)
2007/02/27 Javascript
$.ajax json数据传递方法
2008/11/19 Javascript
自己写的兼容ie和ff的在线文本编辑器类似ewebeditor
2012/12/12 Javascript
JavaScript中圆括号()和方括号[]的特殊用法疑问解答
2013/08/06 Javascript
JavaScript编程的10个实用小技巧
2014/04/18 Javascript
把文本中的URL地址转换为可点击链接的JavaScript、PHP自定义函数
2014/07/29 Javascript
js点击列表文字对应该行显示背景颜色的实现代码
2015/08/05 Javascript
JS判断浏览器是否安装flash插件的简单方法
2016/09/13 Javascript
AngularJs入门教程之环境搭建+创建应用示例
2016/11/01 Javascript
AngularJS创建自定义指令的方法详解
2016/11/03 Javascript
百度搜索框智能提示案例jsonp
2016/11/28 Javascript
canvas绘制表盘时钟
2017/01/23 Javascript
vue axios基于常见业务场景的二次封装的实现
2018/09/21 Javascript
浅谈JavaScript中你可能不知道URL构造函数的属性
2020/07/13 Javascript
[02:25]DOTA2英雄基础教程 虚空假面
2014/01/02 DOTA
[03:59]5分钟带你了解什么是DOTA2(第二期)
2017/02/07 DOTA
python Django连接MySQL数据库做增删改查
2013/11/07 Python
使用Pyinstaller的最新踩坑实战记录
2017/11/08 Python
python中使用xlrd读excel使用xlwt写excel的实例代码
2018/01/31 Python
python实现随机梯度下降法
2020/03/24 Python
Python脚本修改阿里云的访问控制列表的方法
2019/03/08 Python
Django实现web端tailf日志文件功能及实例详解
2019/07/28 Python
解决Python设置函数调用超时,进程卡住的问题
2019/08/08 Python
Python利用WMI实现ping命令的例子
2019/08/14 Python
节能环保口号
2014/06/12 职场文书
临时租车协议范本
2014/09/23 职场文书
党的群众路线教育实践活动领导班子对照检查材料
2014/09/25 职场文书
质监局领导班子对照检查材料思想汇报
2014/09/27 职场文书
python实现三阶魔方还原的示例代码
2021/04/28 Python
python必学知识之文件操作(建议收藏)
2021/05/30 Python
Python基本知识点总结
2022/04/07 Python
Python之Matplotlib绘制热力图和面积图
2022/04/13 Python