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


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 相关文章推荐
html5+javascript制作简易画板附图
Apr 25 Javascript
Bootstrap表单控件学习使用
Mar 07 Javascript
JS控件bootstrap datepicker使用方法详解
Mar 25 Javascript
JavaScript实现三级联动效果
Jul 15 Javascript
深入理解vue.js中$watch的oldvalue与newValue
Aug 07 Javascript
JavaScript变量类型以及变量作用域详解
Aug 14 Javascript
js实现以最简单的方式将数组元素添加到对象中的方法
Dec 20 Javascript
JS Object.preventExtensions(),Object.seal()与Object.freeze()用法实例分析
Aug 25 Javascript
React组件对子组件children进行加强的方法
Jun 23 Javascript
layui使用表格渲染获取行数据的例子
Sep 13 Javascript
layui多图上传实现删除功能的例子
Sep 23 Javascript
vue跳转同一个组件,参数不同,页面接收值只接收一次的解决方法
Nov 05 Javascript
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
php实现把url转换迅雷thunder资源下载地址的方法
2014/11/07 PHP
PHP常见的6个错误提示及解决方法
2016/07/07 PHP
关于Mozilla浏览器不支持innerText的解决办法
2011/01/01 Javascript
给Flash加一个超链接(推荐使用透明层)兼容主流浏览器
2013/06/09 Javascript
通过action传过来的值在option获取进行验证的方法
2013/11/14 Javascript
排序算法的javascript实现与讲解(99js手记)
2014/09/28 Javascript
js控制div弹出层实现方法
2015/05/11 Javascript
javascript实现将文件保存到本地方法汇总
2015/07/26 Javascript
JS截取与分割字符串常用技巧总结
2015/11/10 Javascript
前端框架Vue.js构建大型应用浅析
2016/09/12 Javascript
JS自定义函数对web前端上传的文件进行类型大小判断
2016/10/19 Javascript
Zabbix添加Node.js监控的方法
2016/10/20 Javascript
Jquery EasyUI Datagrid右键菜单实现方法
2016/12/30 Javascript
JavaScript ES6中const、let与var的对比详解
2017/06/18 Javascript
在 Vue.js中优雅地使用全局事件的方法
2019/02/01 Javascript
ES6基础之解构赋值(destructuring assignment)
2019/02/21 Javascript
Vue通过for循环随机生成不同的颜色或随机数的实例
2019/11/09 Javascript
vue+echarts实现动态折线图的方法与注意
2020/09/01 Javascript
Python读取键盘输入的2种方法
2015/06/16 Python
听歌识曲--用python实现一个音乐检索器的功能
2016/11/15 Python
Python向Excel中插入图片的简单实现方法
2018/04/24 Python
Python logging模块用法示例
2018/08/28 Python
pygame游戏之旅 创建游戏窗口界面
2018/11/20 Python
python类中super() 的使用解析
2019/12/19 Python
Python selenium的基本使用方法分析
2019/12/21 Python
Python自动化xpath实现自动抢票抢货
2020/09/19 Python
HTML5 FormData 方法介绍以及实现文件上传示例
2017/09/12 HTML / CSS
Bergfreunde丹麦:登山装备网上零售商
2017/02/26 全球购物
Zavvi西班牙:电子游戏、极客服装、Blu-ray、Funko Pop等
2019/05/03 全球购物
J2EE相关知识面试题
2013/08/26 面试题
团日活动总结模板
2014/06/25 职场文书
通信工程求职信
2014/07/16 职场文书
2016年6月份红领巾广播稿
2015/12/21 职场文书
导游词之台湾安平古堡
2019/12/25 职场文书
Java数组详细介绍及相关工具类
2022/04/14 Java/Android
windows安装 redis 6.2.6最新步骤详解
2022/04/26 Redis