51工具盒子

依楼听风雨
笑看云卷云舒,淡观潮起潮落

vuepress配置cnzz统计

# vuepress 配置 cnzz 统计 {#vuepress-配置-cnzz-统计}

提示

您也可以改用其它方案,如百度统计谷歌统计

# 获取 cnzz 统计代码 {#获取-cnzz-统计代码}

# 配置 cnzz 统计代码 {#配置-cnzz-统计代码}

vi ./config.js

head: [
    // 添加cnzz统计
    [
      "script",
      {
        src: "https://v1.cnzz.com/z_stat.php?id=1278957718&web_id=1278957718"
      }
    ]
  ]

# 切换页面时手工上报 pv 统计 {#切换页面时手工上报-pv-统计}

目前存在一个问题,仅在访问首页或者刷新页面时,才会触发 cnzz 统计。
提示

因为 vuepress 是基于 vue 的单页面应用,所以页面切换过程中,不会重新加载页面,故而不会触发 cnzz 统计。

解决方法: 监听路由切换事件,当切换页面时, 手动上报 cnzz 统计, 具体实现如下:
vi .vuepress/enhanceApp.js

export default ({ router }) => {
  /**
   * 路由切换事件处理
   */
  router.beforeEach((to, from, next) => {
    console.log("切换路由", to.fullPath, from.fullPath);

    //发送cnzz的pv统计
    if (typeof _czc != "undefined") {
      if (to.path) {
        _czc.push(["_trackPageview", to.fullPath, from.fullPath]);
        console.log("上报cnzz统计", to.fullPath);
      }
    }

    // continue
    next();
  });
};

提示

每当切换路由就会触发统计上报。所以发生如下行为时会上报统计:

  • 首次访问
  • 刷新页面
  • 切换到当前文章的其它章节
    切换锚点,URL 会变化,所以会触发路由变化事件。
    所以,当用户完整得浏览完一篇博客时,可能会触发多次上报。 cnzz 统计官方 js-api 文档 (opens new window)
赞(4)
未经允许不得转载:工具盒子 » vuepress配置cnzz统计