tracker
功能
anka-tracker 会将打点任务缓存到队列中,对打点任务做限流处理,避免占用太多HTTP请求导致业务逻辑请求无法顺利完成。另外,当离线或应用关闭时任务会被暂停,直到重新连线/重启后,tracker 会继续先前未完成的任务。
详细配置见 ./src/types/types.d.ts
适用于小程序/小游戏。
使用
安装
以下两种安装方式随意选择:
- 通过 npm 安装:
npm install @anka-dev/tracker --save
- 下载该仓库下 dist/anka-tracker.min.js 文件
初始化
将 anka-tracker.min.js 和 配置文件 anka-tracker.config.js 放置在小程序的开发目录中(两者必须在同一文件夹下)
├── anka-tracker.config.js
├── anka-tracker.js
├── anka-tracker.js.map
├── anka.config.json
├── app.js
├── app.json
├── app.wxss
├── dist
│ └── index.js
├── pages
│ ├── index
│ └── log
├── project.config.json
└── utils
└── util.js
在 app.js
中引入 tracker:
const { tracker } = require('./anka-tracker.js')
并在恰当的时机初始化:
onLaunch (options) {
this.onLaunchOption = options
this.tracker = tracker
wx.login({
complete: () => {
tracker.asyncInitWithCommonData({
open_id: 'mock_open_id',
union_id: 'mock_union_id'
}).then(() => {
console.log('初始化成功,开始执行打点任务')
})
}
})
},
除上面的示例之外,你也可以选择用更灵活的方式初始化:
const { BxTracker } = require('./anka-tracker.js')
const tracker = BxTracker.generateTrackerInstance({
detectChanel: false,
detectAppStart: true
})
API
提供两个打点 API 供开发者使用,建议配置 autoPageView
使用自动打点。
getApp().tracker.evt('click_btn', {
page_id: this.pageId,
custom_data: 'custom_data'
})
getApp().tracker.pv('__viewPage', {
page_id: 'log',
page_type: 'common',
page_title: '详情页',
page_level: 'tabbar_page'
})
参考