首页 > 语言 > JavaScript > 正文

小程序从手动埋点到自动埋点的实现方法

2024-05-06 15:42:55
字体:
来源:转载
供稿:网友

前言

小程序由于封闭性较强,要像web应用一样实现灵活的数据收集,会有一定难度。目前开源的埋点SDK,一般采用手动埋点的方式,这种方式有较强的侵入型,为了解决这个问题就有了该文章。

手动埋点

以腾讯移动分析的SDK为例,如果要记录埋点信息,只要插入一句代码即可

// 例如,记录搜索行为search(keyword) {  if (keyword) {    ...业务代码  }  mta.Event.stat("ico_search", {"query":keyword});}

示例代码看起来是比较简洁的,但是埋点需要收集的数据往往不是单一的,复杂的埋点代码插入业务代码,会 影响代码的阅读体验 ,而且 埋点代码散落在各个地方,不方便管理 。

由于手动埋点必须插入到函数中,有时候我们为了获取页面某一元素点击信息,产生了一种叫无业务相关埋点,简单来说就是你的函数定义,就只有埋点代码,当这种埋点频繁出现, 代码会被严重污染 。

// wxml<view bindtap="track">这只是一个展示view</view>
//js track() { mta.Event.stat("eleClick", {"name":xxxxx});}

另外,由于PM会频繁调整埋点信息,而 埋点是一个繁琐又无聊的工作 ,基于Don't Repeat Yourself 原则,手动埋带要不得。

总结以上,手动埋点有下列问题

影响代码的阅读体验 埋点代码散落在各个地方,不方便管理 代码会被污染 埋点是一个繁琐又无聊的工作

自动埋点

实现思路:监听用户点击-->读取埋点配置JOSN,判断是否需要上报--> 上报数据

1、小程序监听用户点击行为

web应用监听用户点击行为是比较容易,但是小程序没有提供Dom的事件监听,不过我们可以通过事件冒泡的方式捕获。

// web监听页面点击document.addEventListener('click',(e) => {console.log(e)})// 小程序监听页面点击,用户的点击行为都会执行elementTracker方法<view catchtap='elementTracker'> <view class='buy-now'>   <button bindtap='buy' animation="{{scaleAnim}}">立即购票</button> </view></view>

2、判断点击位置是否落在监听元素中

假设需要监听用户是否点击class为buy-now元素,可以通过获取buy-now元素长宽,定位和点击位置坐标判断是否出现重叠,以判断是否被点击。

/** * 判断点击是否落在目标元素 * @param {Object} clickInfo 用户点击坐标 * @param {Object} boundingClientRect 目标元素信息 * @param {Object} scrollOffset 页面位置信息 * @returns {Boolean} */export const isClickTrackArea = function (clickInfo, boundingClientRect, scrollOffset) {  if (!boundingClientRect) return false;  const { x, y } = clickInfo.detail; // 点击的x y坐标  const { left, right, top, height } = boundingClientRect;  const { scrollTop } = scrollOffset;  if (left < x && x < right && scrollTop + top < y && y < scrollTop + top + height) {    return true;  }  return false;};            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选