统计页面学习时长——停留时间

思路

  • 页面进入记录开始时间,开启定时器记录时长
  • 页面离开掉接口
    1. 页面返回 和 浏览器返回 都会执行 beforeDestroy,但是无法掉接口
    2. 所以使用组件内路由守卫beforeRouteLeave,监听返回调取接口
    3. 刷新页面不会执行beforeDestroy和beforeRouteLeave,所以需要监听页面刷新
    4. 监听刷新掉接口会存在有时候接口没有掉成功就刷新完了重新加载了,导致接口没有成功
    5. 所以在页面刷新的时候将 学习时长存储,在mounted 判断本地存储有时长再调取接口
js 复制代码
 <div class="flex pt-10" style="height: 60px">
        <el-page-header @back="goBack" content="知识库"> </el-page-header>
        <div class="flex_r">已学习
        <span class="size-26 green bold ml-10"{{formattedTime}}</span>
    </div>
</div>
      
      
mounted() {
   if (localStorage.getItem("learnTime")) {
      this.setTime(localStorage.getItem("learnTime"));
      localStorage.removeItem("learnTime");
      clearInterval(this.timer); // 页面卸载前清除计时器
      // 组件销毁前,移除事件监听,防止内存泄漏
      window.removeEventListener("beforeunload", this.beforeunloadHandler);
    }
    this.startTime = new Date(); // 页面加载时记录时间
    this.startTimer(); // 开始计时器
    // 页面刷新检测不到beforeDestroy,使用此方法刷新更新视频进度
    window.addEventListener("beforeunload", this.beforeunloadHandler);
  },
  beforeDestroy() {
    console.log("beforeDestroy");
    clearInterval(this.timer); // 页面卸载前清除计时器
    // 组件销毁前,移除事件监听,防止内存泄漏
    window.removeEventListener("beforeunload", this.beforeunloadHandler);
  },
  // 虽然可以监听到beforeRouteLeave,但是无法调取接口
  beforeRouteLeave(to, from, next) {
    console.log("beforeRouteLeave");
    this.$axios
      .put("/qualityTrain/duration/record", {
        duration: this.time,
      })
      .then((res) => {})
      .catch((err) => {})
      .finally(() => {
        next();
      });
  },
  methods: {
    startTimer() {
      this.timer = setInterval(() => {
        const elapsedTime = new Date() - this.startTime; // 计算时间差
        const hours = Math.floor(elapsedTime / 3600000);
        const minutes = Math.floor((elapsedTime % 3600000) / 60000);
        const seconds = Math.floor((elapsedTime % 60000) / 1000);

        // 补零处理
        const formattedHours = String(hours).padStart(2, "0");
        const formattedMinutes = String(minutes).padStart(2, "0");
        const formattedSeconds = String(seconds).padStart(2, "0");
        this.time = parseInt(elapsedTime / 1000);
        this.formattedTime = `${formattedHours}:${formattedMinutes}:${formattedSeconds}`; // 更新显示的时间
      }, 1000);
    },
    // 掉接口
    setTime(time) {
      if (time) {
        console.log(this.formattedTime, this.time, time);
      } else {
        console.log(this.formattedTime, this.time);
      }
    },
    beforeunloadHandler() {
      localStorage.setItem("learnTime", this.time);
    },
    goBack() {
      this.$router.go(-1);
    },
    
}
相关推荐
JustHappy3 小时前
古法编程秘籍(七):互联网到底是什么?把两台电脑怎么说话搞懂就够了
前端·后端·网络协议
老毛肚3 小时前
jeecg-boot-base-core 02 day
javascript·python
snow@li3 小时前
SEO-文章标题:写文章时候,分类+主标题+大纲+解释 作为标题 / 不点进去也知道全文覆盖什么 / 标题即架构
前端
kyriewen4 小时前
Git Commit 前自动修复代码风格?配置 Husky + lint-staged,从此 CR 只聊逻辑
前端·git·面试
岁月宁静4 小时前
RAG 文档摄入全链路,从原理到生产落地
vue.js·人工智能·python
小和尚同志4 小时前
AI 自动化测试探索(一):Playwright MCP
前端·人工智能·aigc
老马识途2.04 小时前
在AI的帮助下理解spring的启动过程
java·前端·spring
徐小夕5 小时前
Loop Engineering 深度解析与实战指南(全网最全)
前端·算法·github
运筹vivo@5 小时前
Python ContextVar 底层机制与内存模型拆解
前端·数据库·python
#麻辣小龙虾#6 小时前
基于vue3.0开发一款【固废与废气运维管理系统】(支持源码)
前端·vue.js·vue3