首页 > 其他分享 >vue项目埋点实践,使用img发送埋点数据

vue项目埋点实践,使用img发送埋点数据

时间:2023-01-28 09:34:33浏览次数:33  
标签:vue console log img state Vue 埋点

埋点数据种类:
1.按钮点击
2.页面切换
(具体数据内容根据实际需求再定义)

埋点数据交互:
采用img的默认下载功能,发送get请求,带上埋点数据(此处后期需要加上加密)

发送频率:
1.固定时间
2.固定数据量(根据get请求的限制和每条埋点的数据量制定最大的存储数据量)

 

代码如下

main.js

1.自定义指令监听发送

2.页面切换监听

 1 import Vue from 'vue'
 2 import App from './App.vue'
 3 import router from './router'
 4 import store from './store'
 5 // import axios from 'axios'
 6 import ElementUI from 'element-ui';
 7 import 'element-ui/lib/theme-chalk/index.css';
 8 import JsonExcel from 'vue-json-excel'
 9 import { get, post } from '@/util/http'
10 
11 Vue.config.productionTip = false
12 // Vue.prototype.$axios = axios
13 Vue.prototype.$post = post;
14 Vue.prototype.$get = get;
15 Vue.use(ElementUI)
16 Vue.component('downloadExcel', JsonExcel)
17 
18 new Vue({
19   router,
20   store,
21   render: h => h(App)
22 }).$mount('#app')
23 
24 /**
25  * 自定义埋点指令
26  */
27 Vue.directive('log', {
28   bind(el, binding, vNode) {
29     // 当前页面的vue对象
30     const ts = vNode.context
31     el.addEventListener('click', () => {
32       console.log('v-log指令', binding.value)
33       const text = binding.value.text
34       store.dispatch('dealLogger', {
35         type: '点击操作',
36         text,
37         curPage: ts.$route.name,
38         timeStamp: '事件发生的时间戳' + new Date().getTime() // 时间戳
39       })
40     })
41 
42   }
43 
44 })
45 
46 let currentTime = null
47 let startTime = Date.now()
48 
49 router.beforeEach((to, from, next) => {
50   console.log('beforeEach')
51   if (to) {
52     // 第一步:页面跳转后记录一下当前的时间 currentTime
53     currentTime = Date.now()
54     // 第二步:计算 currentTime - startTime 的 差值 
55     console.log('用户由 ', from.name, ' 页面 跳转到 ', to.name, ' 页面,在 ', from.name, ' 页面停留了 ', currentTime - startTime, '毫秒。转换成秒数约为:', parseInt((currentTime - startTime) / 1000))
56     // 通过计算currentTime - startTime 的 差值 之后,再上报数据
57     const sed = parseInt((currentTime - startTime) / 1000)
58     store.dispatch('dealLogger', {
59       type: '页面切换',
60       prePage: from.name, // 上一个页面
61       curPage: to.name, // 当前页面
62       timeStay: '停留了' + sed + 's', // 停留时间
63     })
64 
65     // 第三步:每次都要初始化一下 startTime
66     startTime = Date.now()
67   }
68   next()
69 })
70 
71 // Vue.config.errorHandler = (err, vm, info) => {
72 //   console.log('*************************************************************************************addEventListener errorHandler')
73 //   console.log(err)
74 //   console.log(vm)
75 //   console.log(info)
76 //   }
77 
78 // window.addEventListener('error', (evt) => {
79 //   console.log('*************************************************************************************addEventListener error')
80 //   console.log(evt)
81 // })
82 
83 // // 监听promise的报错
84 // window.addEventListener('unhandledrejection', (evt) => {
85 //   console.log('*************************************************************************************addEventListener unhandledrejection')
86 //   console.log(evt)
87 // })

 

vuex文件

export default {
    state: {
        logUrl: 'https://kunpeng.csdn.net/ad/json/list', // 发送埋点的url
        loggerResult: [], // 埋点数据统计
        logLength: 5, // 最大存储埋点数量
        logTime: 60, //  发送埋点间隔时间
    },
    getters: {
        getLogTime: state => state.logTime,
        getLoggerResult: state => state.loggerResult
    },
    mutations: {
        /**
         * 添加埋点数据
         * @param {*} state 
         * @param {*} payload 
         */
        appendLogger: (state, payload) => {
            state.loggerResult.push(payload)
        },
        /**
         * 清空埋点数据
         * @param {*} state 
         * @param {*} payload 
         */
        resetLogger: (state) => state.loggerResult = [],
    },
    actions: {
        /**
         * 处理埋点数据
         * @param {*} param0 
         * @param {*} payload 
         */
        dealLogger({ state, commit, dispatch }, payload) {
            console.log('dealLogger****************', payload)
            commit('appendLogger', payload)
            const res = state.loggerResult
            // 当埋点数量超出定义的最大存储数量,发送一次
            if (res.length >= state.logLength) {
                dispatch('sendLogger')
            }
        },
        /**
         * 发送埋点数据
         * @param {*} param0 
         * @param {*} payload 
         */
        sendLogger({ state, commit }) {
            const res = state.loggerResult
            // 如果没有埋点数据,则不发送
            if (res.length === 0) {
                return
            }
            // 发送数据
            console.log('sendLogger loggerResult', res)
            const img = new Image()

            img.style.display = 'none'

            const removeImage = function () {
                img.parentNode.removeChild(img)
            }

            img.onload = removeImage
            img.onerror = removeImage

            img.src = `${state.logUrl}?params=${JSON.stringify(res)}`

            document.body.appendChild(img)
            // 清空
            commit('resetLogger')
        }
    },
    modules: {
    }
}

页面具体实现

v-log绑定相关信息

<div class="btn">
        <el-form-item>
          <el-button type="primary" @click="onSubmit" v-log="{text: '查询'}">查询</el-button>
        </el-form-item>
        <el-form-item>
          <el-button type="" @click="onReset" v-log="{text: '重置'}">重置</el-button>
        </el-form-item>
      </div>

 

标签:vue,console,log,img,state,Vue,埋点
From: https://www.cnblogs.com/fengyingYZ/p/17069655.html

相关文章

  • Vue Router 的导航守卫内部使用pinia | 报错getActivePinia was called with no activ
    运行环境"pinia":"^2.0.28","vue":"^3.2.45","vue-router":"^4.1.6"触发错误代码import{createWebHistory,createRouter}from'vue-router'importuseMenuS......
  • Vue三大路由守卫
    Vue路由守卫路由守卫,简单理解来说就是,当用户要进行一些操作时,需要用户的一些信息或数据或行为,判断过后,才会同意用户进行操作。说到这里,大家心里都或多或少有点理解了吧,官......
  • vue3的unplugin-auto-import自动引入
    vue3的unplugin-auto-import,setup语法糖下自动引入vue的基本apihttps://blog.csdn.net/weixin_52020362/article/details/127841641......
  • vue路由缓存的三种方式
    1.全部缓存使用Keep-alive标签包裹router-view就可以实现全部缓存<keep-alive><router-view></router-view></keep-alive>2.缓存单个指定的路由同样使用Keep-ali......
  • vue图片读取
    <el-form-itemlabel="头像"prop="pass"><imgv-bind:src="imgSrc"style="width:100px;"><inputtype="file"ref="myfile"id="fileId......
  • Vue3.2 新增 v-memo
    这个指令是​​Vue3.2​​新增的内置指令,大致的作用就是小幅度手动提升一部分​​性能​​官网文档​​cn.vuejs.org/api/built-i…​​用法在组件和元素都可以使用,主要是......
  • Vue3 封装扩展并简化Vuex在组件中的调用
    如果你在项目中使用了vuex模块化,并且在项目中使用actions中函数调用频率高,推荐了解一下这种方式。比如下面两种方式调用,第一个是直接传参设置,第二个是添加了异步ajax......
  • 用 Vue.js 实现一个 JSON Viewer
    演示地址:http://json.imlht.com/vue-json-viewer-demo.html常用的JSON格式化工具JSON是一种轻量级的数据交换格式,相信大家用得比较多,平时也用了很多格式化工具......
  • 理解vue中的scope的使用
    我们都知道vueslot插槽可以传递任何属性或html元素,但是在调用组件的页面中我们可以使用templatescope="props"来获取插槽上的属性值,获取到的值是一个对象。注意:scope="......
  • vue路由
    视频链接:https://www.bilibili.com/video/BV1Zy4y1K7SH?p=118什么是vue路由?答:概念是这么说的嗷:路由的本质就是一种对应关系,比如说url地址和资源之间的对应关系。我来简......