前言
前端埋点主要分为页面埋点和事件埋点
官方文档:https://help.aliyun.com/document_detail/201089.html
页面埋点
import { sendTrack} from '@/util/quickTracking'
sendTrack({
eventName: '***_page',
params: {}
})
事件埋点
import { sendTrackEvent } from '@/util/quickTracking'
sendTrackEvent({
eventName: '**_click',
params: {}
})
初始化埋点方法
import config from '@/config/env'
import { getUserInfo } from '@/util/auth/func'
const {
appKey,
trackHost,
sdkUrl
} = config.tracking
export const EventType = {
Exp: 'EXP',
Click: 'CLK',
Other: 'OTHER'
}
export function init() {
if (!window.aplus_queue) {
initQueue()
loadQuickTrackSDK()
.then(() => {
setUserInfo()
})
}
}
export function sendTrackEvent({
eventName,
pageName = eventName,
eventType = EventType.Click,
params
}) {
console.log('qt event', eventName, pageName, eventType, params)
window.aplus_queue.push({
action: 'aplus.record',
arguments: [eventName, eventType, {
...params,
page_name: pageName
}]
})
}
export function sendTrack({
eventName,
pageName = eventName,
params
}) {
console.log('qt tracking', eventName, pageName, params)
window.aplus_queue.push({
action: 'aplus.sendPV',
arguments: [{
is_auto: false
}, {
// ts: Date.now(),
// path: eventName, // 当前page的url
page_name: pageName,
...params
}]
})
}
function initQueue() {
window.aplus_queue = []
// 手动 PV
window.aplus_queue.push({
action: 'aplus.setMetaInfo',
arguments: ['aplus-waiting', 'MAN']
})
// 集成应用的appKey
window.aplus_queue.push({
action: 'aplus.setMetaInfo',
arguments: ['appKey', appKey]
})
// 如果是私有云部署还需要在上面那段JS后面紧接着添加日志域名埋点
if (trackHost) {
window.aplus_queue.push({
action: 'aplus.setMetaInfo',
arguments: ['aplus-rhost-v', trackHost]
})
}
// 关闭全埋点
window.aplus_queue.push({
action: 'aplus.setMetaInfo',
arguments: ['aplus-autotrack-enabled', false]
})
window.aplus_queue.push({
action: 'aplus.setMetaInfo',
arguments: ['_hold', 'BLOCK']
})
}
async function loadQuickTrackSDK() {
// qt的库回覆盖window.history的函数 pushState, replaceState 函数并导致IE11报错
// 这里覆盖回去
const nativePushState = window.history.pushState
const nativeReplaceState = window.history.replaceState
return new Promise((resolve) => {
const $scriptInDOM = document.getElementsByTagName('script')[0]
const $script = document.createElement('script')
$script.async = true
$script.id = 'beacon-aplus'
$script.src = sdkUrl
$script.onload = () => {
// qt库内部在body渲染之后延时51,这里延时200应该足以覆盖
sleep(200).then(() => {
window.history.pushState = nativePushState
window.history.replaceState = nativeReplaceState
resolve()
})
}
$scriptInDOM.parentNode.insertBefore($script, $scriptInDOM)
})
}
async function setUserInfo() {
const userInfo = await getUserInfo()
if (userInfo) {
window.aplus_queue.push({
action: 'aplus.setMetaInfo',
arguments: ['_user_id', userInfo.user_id]
})
}
window.aplus_queue.push({
action: 'aplus.setMetaInfo',
arguments: ['_hold', 'START']
})
}
async function sleep(ms) {
return new Promise((resolve) => {
setTimeout(resolve, ms)
})
}
埋点信息配置
const config = {
webId: '',
// QuickTracking
appKey: '',
trackHost: '',
sdkUrl: ''
}
export default config
埋点验证
开发的时候一般是通过console.log验证参数是否正确。正式的验证要在Quick Tracking平台上验证
选择对应的平台点击开始验证
埋点验证.png
输入对应的验证地址,生成验证地址
埋点验证.png
当你开始访问验证地址,会自动跳转到对应的埋点信息列表
0人点赞
前端PLAY
分享到:
相关推荐
# 基于Java Web的饮品销售管理系统 ## 项目简介 本项目是一个基于Java Web的饮品销售管理系统,主要用于学校实训课程的作业。系统涵盖了从用户管理、商品管理、订单管理到购物车管理的全套功能,旨在提供一个完整的在线饮品销售解决方案。 ## 项目的主要特性和功能 ### 用户管理 用户注册与登录支持用户注册新账号和登录系统。 用户信息管理包括用户信息的查询、修改和删除。 用户类型管理区分不同类型的用户(如管理员、普通用户)。 ### 商品管理 商品CRUD操作支持商品的添加、修改、删除和查询。 商品分类管理支持多级商品分类的查询和管理。 商品分页查询支持按页查询商品信息,提高查询效率。 ### 订单管理 订单CRUD操作支持订单的创建、修改、删除和查询。 订单明细管理支持订单明细的添加和管理。 订单状态管理支持订单状态的更新和查询。 ### 购物车管理
BitmapFunc
c++课程设计-产品入库管理操作系统
c语言火车票订票管理源码
仿新浪微博下拉刷新继承FrameLayout
浮动搜索框(SearchManager)
# 基于Particle Tracker框架的传感器浮标系统 ## 项目简介 本项目是一个基于Particle Tracker框架的传感器浮标系统,旨在通过集成多种传感器和通信模块,实现对环境参数的实时监测和数据传输。该系统主要应用于海洋监测、环境监测等领域,通过浮标上的传感器收集温度、湿度、位置等数据,并通过Particle Tracker平台进行数据处理和传输。 ## 项目的主要特性和功能 1. 传感器集成 集成BMI160传感器,用于检测三轴加速度和三轴陀螺仪数据。 集成Grove温度和湿度传感器,用于实时监测环境温度和湿度。 集成NTC热敏电阻,用于精确测量温度变化。 2. 位置追踪 使用UBLOX GPS模块,提供高精度的位置追踪功能。 支持地理围栏功能,能够检测浮标是否进入或离开预设区域。 3. 数据通信 通过CAN总线实现传感器数据的高效传输。
<项目介绍> - 树莓派使用OpenCV库实现人脸识别 - 不懂运行,下载完可以私聊问,可远程教学 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载学习,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可用于毕设、课设、作业等。 下载后请首先打开README.md文件(如有),仅供学习参考, 切勿用于商业用途。 --------
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。
PHP基于Linux的远程管理系统服务器端的实现(源代码+论文)
c语言课程设计-产品管理系统
一个智能问答系统,能够自动将用户的自然语言问题转换成 SQL 查询,并以可视化形式展示结果 用户使用自然语言查询数据。基于 Python、MySQL 和 Milvus 构建,将用户的问题转换为 SQL 查询,安全地执行,并产生符合echarts的数据可视化呈现结果。
医生健康科普问答咨询平台(前端+后台)源码带手机端 医生健康科普问答咨询平台,主要提供专业、及时的健康咨询服务,问题涵盖面广,包括内科、外科、 妇科、儿科、男科、中医、五官、等科室。可以通过视频,音频,文章,问答等方式进行科普。 前台首页:1、包含幻灯片 2、权威医生 3、医学视频 4、语音科普 5、科普文章。 6、健康问答 7、个人中心。 网站管理后台:各模块可以灵活管理和配置。 1、信息管理: (1)会员系统。(2)轮播系统。(3)权威医生。(4)医学视频。(5)语音科普。 (6)科普文章。(7)健康问答。(8)友情链接。(9)帮助中心。(10)栏目板块。 2、用户管理:(1)管理员管理。(2)部门管理。(数据权限)(3)用户组管理。(菜单权限) 3、页面管理:(1)高级标签(SQL)。(2)自定义静态标签。(3)静态页面生成。 4、系统管理:(1)网站参数管理。 (2)模型管理。(可以生成板块,对应字段后台展示不同控件,并有相应维护功能,可以根据模型 及模型下栏目创建标签,将标签放入html模板中,生
# 基于Python和OpenMV Camera的图像处理与通信系统 ## 项目简介 本项目基于OpenMV Camera,结合MicroPython,实现了图像捕获、处理与通信功能。通过UART和SPI协议,实现了与Arduino和ESP32等设备的通信,实现了图像数据的传输和接收。项目涵盖了图像捕获、处理、传输、反馈等多个环节,旨在实现机器视觉应用中的图像数据采集与通信。 ## 主要特性和功能 1. 图像捕获使用OpenMV Camera进行图像捕获,支持灰度图像和彩色图像。 2. 图像处理对捕获的图像进行二值化、灰度转换等处理,用于后续机器视觉任务。 3. UART通信通过UART接口,实现与Arduino、ESP32等设备的通信,发送和接收图像数据。 4. SPI通信作为SPI从设备,与Arduino主设备进行通信,实现数据的传输。 5. LED状态指示使用LED灯指示程序运行状态和图像捕获处理进度。
gee python 教程(西班牙语)
按钮点击WIN8 磁贴效果
动态ListView,支持异步更新列表,异步更新图片
PHP教材管理系统设计(源代码+论文)
将jar文件转换为exe
# 基于Spring Boot和MyBatis的宿舍管理系统 ## 项目简介 本项目是一个基于Spring Boot和MyBatis框架开发的宿舍管理系统,旨在为学生、宿管和后勤人员提供一个高效的管理平台。系统支持用户管理、房间管理、楼宇管理、维修申请等功能,并具备人性化的宿舍分配和可视化的账单管理。 ## 项目的主要特性和功能 1. 用户管理系统中的用户分为学生、宿管和后勤三类,每类用户拥有不同的操作权限。 2. 房间管理支持房间的创建、删除、更新和查询操作,以及房间容量的调整。 3. 楼宇管理支持楼宇的创建、删除、更新和查询操作,以及楼宇入住率和性别信息的统计。 4. 维修申请学生可以提交维修申请,宿管和后勤人员可以管理和处理这些申请。 5. 账单管理支持账单的创建、删除、更新和查询操作,以及Excel文件的上传和数据导入。 6. 宿舍分配系统提供人性化的宿舍分配功能,支持根据学生的意向进行分配。