



下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第JavaScript利用img实现前端页面埋点功能目录数据类型技术方案如何设计完整代码总结做数据分析的时候,可能会遇到一个问题:如何获取足量的有效数据。简单记录用户登录IP肯定是不能满足要求的,这个时候就需要我们在前端页面埋点,也就是数据采集点。如何来实现一个前端埋点功能,本文就带你上手试试。
数据类型
首先,我们需要明确埋点需要哪些数据,这个和具体的业务需求有关。但是我们设计的时候,还是应该尽量考虑:
pv:页面访问量uv:用户访问量自定义事件页面性能加载数据报错信息
埋点数据范围清晰了,那么怎么来实现埋点呢?
技术方案
首先我们不建议使用ajax发送http的方式将埋点数据发送到服务端,原因主要有两个:
可能存在跨域的风险,例如使用第三方的接口可能存在兼容性问题,例如使用fetch来发送请求就不兼容IE
其他原因也有,但不是主要的。这里,我们建议使用img或者script来实现埋点数据的发送,这两个属于原生的HTML属性,兼容性比ajax要好很多,而且支持跨域。img和script如果要细分的话,还是有差异的,感兴趣的朋友可以移步:详解JavaScript发送埋点请求的两种方式,本文将选择img来实现埋点。
如何设计
在写代码前,可以先设计出代码大概的结构,这样在写的时候才会思路清晰。在埋点数据中,性能分析和错误监听可能会复杂一点。性能分析可以使用performance.timing
performance的每一个属性的作用节点可参考下图:
错误监听可参考文章:如何监听Vue项目报错的4种方式
完整代码
classStatisticsSDK{
constructor(){
this.initPerformance();//性能分析
this.initError();//错误监听
//初始化性能分析
initPerformance(){
consturl='xxx';
this.send(url,performance.timing)
//初始化错误监听
initError(){
window.addEventListener('error',event={
const{error,lineno,colno}=event;
this.error(error,{lineno,colno})
//Promise未catch的错误
window.addEventListener('unhandledrejection',event={
this.error(newError(event.reason),{type:'unhandledrejection'})
//发送埋点数据,作为公共方法被调用
send(url,params={}){
params.id=Date.now();//当前时间戳
constarr=[];
for(letkeyinparams){
arr.push(`${key}=${params[key]}`);
constnewUrl=`${url}${arr.join('')}`;//参数拼接在请求地址上
//使用img发送埋点数据
//constimg=newImage();
//img.src=newUrl;
constimg=document.createElement('img');
img.src=newUrl;
//页面访问量
pv(){
consturl='xxxx'
//调用send发送
this.send(url,{key:'pv',value:location.href})
//自定义事件
event(key,value){
consturl='xxxx';//服务端地址
//调用send发送
this.send(url,{key,value})
//未捕获的错误,或者用户自行发送错误埋点数据时
error(error,info={}){
consturl='xxx';
const{message,stack}=error;
this.send(url,{message,stack,...info})
consts=newStatisticsSDK();
总结
本文主要使用img来实现埋点数据的发送,考虑了跨域、兼容性,但
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 企业品牌与战略价值提升试题及答案
- 经济周期理论与现实分析试题及答案
- VB学习经验积累试题及答案
- 软件水平考试经典案例分析试题及答案
- 金融科技对银行业的影响试题及答案
- 2025年法学概论考试角度的反思试题及答案
- 业务发展策略计划
- 2025年计算机二级VB创新试题及答案
- 2025车库买卖合同书模板
- 培养小班孩子生活自理能力的工作要点计划
- 心理危机干预培训课件
- 2023年心血管内科学考博真题
- 保温杯生产工艺流程
- GB/T 6482-2007凿岩用螺纹连接钎杆
- 理正深基坑算例
- 公司休假销假单模板
- 《基于杜邦分析法的企业财务分析国内外文献综述》
- 全国高中数学联赛广东省预赛试题及解答
- DB33T 2226-2019 空气负(氧)离子观测与评价技术规范-纯图
- 高中政治教学的经验分享课件
- 办公室事故防范(典型案例分析)
评论
0/150
提交评论