聊聊前端埋点 clarity:我会一直视监你... 永远...

前言

最近想简单看一下项目的使用情况。做产品切忌自嗨,写了很久的模块,结果只有自己用,还更新的挺起劲,这就无意义了。

为了防止这种情况,我们一般会选择接入一个埋点平台,进行页面点击、曝光等操作的上报,最后对这些数据进行分析,就可以知道具体的情况了。

不过今天暂时不聊这种传统的埋点,介绍一下微软的埋点之作:clarity

展示

如图所示,这是一个正常的用户窗口,进行了一些简单的点击操作

与此同时,另外一边,我们在埋点 平台 ,居然能看到用户正在做什么?!

不是哥们?连轨迹都给你录下来了,看完这个功能,我脑子里只有这些表情包

同时也深深敬佩微软的工程师,如此复杂的监控页面,是怎么通过几个埋点事件就可以完美呈现的。只能想到个dom 快照,但深究起来真是半点不懂。

更夸张的是,接入只需要三行代码。是的,你只需要在项目里加入这三行代码,就可以视监你的用户了。

js 复制代码
import Clarity from '@microsoft/clarity';
const projectId = 'xxxxxxxx';
Clarity.init(projectId);

完整接入流程

  1. 添加一个项目

clarity.microsoft.com/projects?sn...

  1. 选一种方案接入,一般就 npm 了
js 复制代码
// 接入到起始文件中,index.js / main.js 等
import Clarity from '@microsoft/clarity';
const projectId = 'xxxxxxxx';
Clarity.init(projectId);
  1. 在设置中找到项目id,替换掉刚才的 projectId
  1. 到这就完工了,不过检查一下项目运行时有没有正常触发埋点(埋点为 collect)

搞定,非常简单,之后我们就可以直接在平台视监用户了

略微配置

更详细的笔者还没研究,且分享一个 case,我们在录制的时候往往需要用户的信息,来知道是谁进行了操作,我们可以通过设置标签来达成这一效果。

也就是调用了一下 setTag 方法

js 复制代码
export const initClarity = (user: string) => {
  Clarity.init(projectId);
  Clarity.setTag('user', user);
};

over,今天的分享很简单,下班!

相关推荐
weixin199701080164 小时前
【性能提升300%】仿1688首页的Webpack优化全记录
前端·webpack·node.js
冰暮流星5 小时前
javascript之数组
java·前端·javascript
晚霞的不甘5 小时前
Flutter for OpenHarmony天气卡片应用:用枚举与动画打造沉浸式多城市天气浏览体验
前端·flutter·云原生·前端框架
xkxnq5 小时前
第五阶段:Vue3核心深度深挖(第74天)(Vue3计算属性进阶)
前端·javascript·vue.js
三小河5 小时前
Agent Skill与Rules的区别——以Cursor为例
前端·javascript·后端
Hilaku5 小时前
不要在简历上写精通 Vue3?来自面试官的真实劝退
前端·javascript·vue.js
三小河6 小时前
前端视角详解 Agent Skill
前端·javascript·后端
Aniugel6 小时前
单点登录(SSO)系统
前端
鹏多多6 小时前
移动端H5项目,还需要react-fastclick解决300ms点击延迟吗?
前端·javascript·react.js
serioyaoyao6 小时前
上万级文件一起可视化,怎么办?答案是基于 ParaView 的远程可视化
前端