当前位置: 首页 > news >正文

部分页面统计用户访问时长

方式1

import { createApp } from "vue";
import { createPinia } from "pinia";import App from "./App.vue";
import router from "./router";const app = createApp(App);app.use(createPinia());
app.use(router);// 初始化变量
let startTime = 0; // 开始计时时间
let totalDuration = 0; // 总浏览时长(秒)
let isActive = false; // 页面是否活跃// 页面加载时开始计时
window.addEventListener("load", () => {console.log("页面加载完毕");startTime = Date.now();isActive = true;
});// 监听页面可见性变化(切换标签页、最小化窗口)
document.addEventListener("visibilitychange", () => {// console.log("visibilitychange");if (document.hidden) {// 页面隐藏:停止计时,累加时长if (isActive) {totalDuration += Math.floor((Date.now() - startTime) / 1000);isActive = false;}} else {// 页面显示:重新开始计时startTime = Date.now();isActive = true;}
});// 监听窗口焦点变化(切换到其他应用时)
window.addEventListener("blur", () => {console.log("blur");if (isActive) {totalDuration += Math.floor((Date.now() - startTime) / 1000);isActive = false;}
});window.addEventListener("focus", () => {console.log("focus");startTime = Date.now();isActive = true;
});// 页面卸载时处理时长(上报或存储)
window.addEventListener("beforeunload", (event) => {// 累加最后一次活跃时长if (isActive) {totalDuration += Math.floor((Date.now() - startTime) / 1000);}// 1. 存储到本地 localStorage(刷新后仍可获取)localStorage.setItem("pageBrowseDuration", totalDuration);// 2. 上报到服务器(示例:通过接口提交)// fetch('/api/report-duration', {//   method: 'POST',//   headers: { 'Content-Type': 'application/json' },//   body: JSON.stringify({ duration: totalDuration, url: window.location.href })// });console.log("当前页面浏览时长:", totalDuration, "秒");
});app.mount("#app");

方式2

// src/main.jsimport { createApp } from "vue";
import { createPinia } from "pinia";import App from "./App.vue";
import router from "./router";const app = createApp(App);app.use(createPinia());
app.use(router);let pageTimers = {}; // 存储各个页面的计时信息// 路由前置守卫
router.beforeEach((to, from, next) => {const now = Date.now();// 如果有正在计时的页面,则结束它的计时并保存if (from.meta.trackTime) {if (pageTimers[from.path]) {pageTimers[from.path].duration += Math.floor((now - pageTimers[from.path].start) / 1000);delete pageTimers[from.path];}}// 如果即将进入需要追踪的页面,则开始新的计时if (to.meta.trackTime) {pageTimers[to.path] = {start: now,duration: 0};}next();
});// 页面卸载前上报数据
window.addEventListener("beforeunload", () => {const now = Date.now();// 结束所有正在进行的计时for (let path in pageTimers) {pageTimers[path].duration += Math.floor((now - pageTimers[path].start) / 1000);// 可以在这里发送每个页面的数据到服务器或本地存储console.log(`页面 ${path} 浏览时长:`, pageTimers[path].duration, "秒");// 示例:存储到 localStorage 或发送至服务端localStorage.setItem(`pageDuration_${path}`, pageTimers[path].duration);}
});app.mount("#app");
http://www.jsqmd.com/news/33610/

相关文章:

  • 单词故事
  • 【Linux笔记】网络部分——Socket编程 UDP搭建网络云服务器与本地虚拟机的基本通信
  • 11月6日日记
  • 102302149赖翊煊数据采集第二次作业
  • ai学习机哪个品牌好?松鼠 AI 双线矩阵:学习机 + 自习室,提分更高效
  • 招聘实习生丨加入我们,共建 RTE 开发者社区
  • 引领未来,智启新程:Compete MIS平台——低代码时代的全能信息化管理解决方案
  • 终端
  • 2025.11.06 - A
  • CF2085D Serval and Kaitenzushi Buffet
  • STM32时钟学习11.6
  • 2025.11.6总结
  • 高级程序语言设计的四次作业
  • 11月6日
  • 2024 暑期模拟赛 #11
  • startctf环境变量注入及强网拟态smallcode特殊解法
  • Spring ApplicationEventPublisher 事件发布
  • NOIP模拟赛20251106 T4 CF1270H
  • 详细介绍:电阻的分类与应用
  • 题解:CF2121E Sponsor of Your Problems
  • wepoc Nuclei 漏洞扫描器图形界面工具
  • Python实现数据可视化用Matplotlib轻松创建专业级图表 - 指南
  • Python因果分析选哪个?六个贝叶斯推断库实测对比(含代码示例)
  • 题解:CF2121B Above the Clouds
  • 实用指南:学习日报 20251007|深度解析:基于 Guava LoadingCache 的优惠券模板缓存设计与实现
  • 选择 Tita 新绩效一体化的 5 大理由
  • NOIP模拟赛20251106 T3
  • 20251106周四日记
  • 学习:初学BP
  • 2025年上海防水补漏TOP5最新评测:从屋顶到地下室,全场景解决