监控平台之pv&uv/点击事件/路由上报

pv/uv上报方式
// 这里是pv的上报方式
// 可以用自定义标签定义data-spider,通过body-parser等方式获取body标签的值,进行上报
// 

export default function pv() {
    const reportData = {
        type: 'behavior',
        subType: 'pv',
        startTime: performance.now(),
        pageUrl: window.location.href,
        uid: generateUniqueId(),
        referrer: window.referrer,
    }
    lazyReportBatch(reportData) 
}

// 可以自定义按钮的上报函数,暴露给外部调用
export default function funPV(options) {
    const reportData = {
        type: 'behavior',
        subType: 'pv',
        startTime: performance.now(),
        pageUrl: window.location.href,
        uid: generateUniqueId(),
        referrer: window.referrer,
    }
    for (const key in options) {
        if (reportData.hasOwnProperty(key)) {
            reportData[key] = options[key];
        }
    }
    lazyReportBatch(reportData) 
}
点击事件上报

监听mousedown,touchstart进行监听点击事件,

import {lazyReportBatch} from "../report"

export default function click() {
    ['mousedown', 'touchstart'].forEach(eventType => {
        window.addEventListener(eventType, e => {
            const target = e.target;
            if (!target.tagName) {
                return
            }
            const reportData = {
                type: 'behaviour',
                subType: 'click',
                pageUrl: window.location.href,
                target: target.tagName,
                clientX: e.clientX,
                clientY: e.clientY,
                startTime: e.timeStamp,
                innerHtml: target.innerHtml,
                outerHtml: target.outerHtml,
                width: target.offsetWidth,
                height: target.offsetHeight,
                path: e.path
            }
            lazyReportBatch(reportData) 
        })
    })
}
路由上报

分为hashchange和popstate,根据是否有#进行分别,区别如下

hashChange 触发条件

hash是URL中#后面那部分,同时修改hash值不会引起页面的刷新,也不会向服务器重新发送请求。通过hashchange事件可以监听它的变化。改变hash值有以下三种方式:

  • 浏览器前进后退改变URL
  • 通过a标签锚点方式改变URL。
  • 通过window.location.hash改变URL
  • 调用history的back、go、forward方法

不能触发事件的方式

  • pushState和replaceState

备注:以上三种方式均可以触发hashchang事件, pushState和replaceState均不能触发hashchang事件

popstate触发条件

history提供了popstate监听事件,但是只有以下两种情况会触发该事件

  • 点击浏览器前进后退的按钮
  • 显示调用history的back、go、forward方法
  • 不能触发事件的方式

pushState和replaceState

  • a标签不能触发,因为非锚点模式直接跳转了页面。

这里记录了路由的from路径和to路径,根据业务具体需求上报参数

import {lazyReportBatch} from "../report"
import {generateUniqueId} from "../../utils"

export default function pageChange(data) {
    // hash history

    let oldUrl = ''
    window.addEventListener('hashchange', function(event) {
        const newUrl = window.location.href;
        const reportData = {
            from: oldUrl,
            to: newUrl,
            type: 'behavior',
            subType: 'hashchange',
            pageUrl: window.location.href,
            startTime: this.performance.now(),
            uuid: generateUniqueId(),
        }
        lazyReportBatch(reportData) 
        oldUrl = newUrl;
    }, true); 

    // 点击后退前进的时间
    let from = ''
    window.addEventListener('poststate', function(event) {
        const to = window.location.href;
        const reportData = {
            from,
            to,
            type: 'behavior',
            subType: 'poststate',
            pageUrl: window.location.href,
            startTime: this.performance.now(),
            uuid: generateUniqueId(),
        }
        lazyReportBatch(reportData) 
        from = to;
    }, true); 
} 

  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CSP:指的是Content Security Policy(内容安全策略),它是一种用于保护网站免受跨站脚本攻击(XSS)和数据注入攻击的安全机制。通过设置CSP,网站管理员可以控制浏览器只加载指定来源的资源,从而减少恶意代码的风险。 CSV:指的是Comma-Separated Values(逗号分隔值),它是一种常见的文件格式,用于存储和传输表格数据。CSV文件中的每一行代表一个数据记录,每个字段之间使用逗号进行分隔。 PP:指的是Privacy Policy(隐私政策),它是一种声明或公告,用于告知用户个人信息的收集、使用和保护方式。隐私政策通常出现在网站、应用程序或服务的页面上,以确保用户了解其个人信息的处理方式。 PV:指的是Page View(页面浏览量),它是衡量网站或应用程序页面被访问的次数。PV可以用来评估网站或应用程序的流量和受欢迎程度。 PT:指的是Performance Testing(性能测试),它是一种测试方法,用于评估系统、应用程序或网站在不同负载条件下的性能表现。性能测试可以帮助发现系统瓶颈、优化性能和提高用户体验。 HM:可能是指Hash Map(哈希映射),它是一种数据结构,用于存储键值对。哈希映射通过将键映射到唯一的索引位置来实现快速的查找和插入操作。哈希映射在计算机科学中被广泛应用于各种算法和数据处理任务。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值