Vue 页面监听用户预览时间功能的实现代码
作者:太空编程 发布时间:2024-04-27 15:56:25
最近的业务中涉及到这样一个需求,在线培训的系统需要知道用户对某个在线预览的页面追踪用户的预览时长。初步我们首先想到借助 Vue 页面的生命周期函数 mounted
和 destroyed
,分别在其中加入开始计时和清除计时的逻辑,通过后台的接口上报对应的培训素材的时间数据,即可达到目的。
有了思路,我们就可以开始筹划具体的代码。
定义开始结束计时函数
在 data
中定义我们通过变量定义计时器,这样可以通过 this.timer
随处可访问,便于后面销毁页面的时候清除它。
duration
为时长的计数变量,初始化为 0,可根据计时器的第二个时间间隔参数,决定单位是秒还是毫秒。
export default {
data() {
return {
timer: null,
duration: 0
}
},
methods: {
startTimer() {
this.timer = setInterval(() => {
console.log('观看时长: ', this.duration)
this.duration++
}, 1000)
},
stopTimer() {
clearInterval(this.timer)
this.updateViewHistory() // 上报数据接口
},
updateViewHistory() {
// 上报接口逻辑代码
....
}
}
}
在 startTimer
函数中我们顺便打印出 duration
变量来验证显示的时间是否正确。
如何以及在哪调用
定义好了开始结束的方法,我们就要开始想在哪调用它们。因为预览的页面内容不是唯一的,是根据素材的 id
来获取详情进行渲染的。如果我们把 startTimer
写在 mounted
生命周期里,那么当我们访问不同 id
的页面的时候,无法正常切换我们想要的逻辑。
所以我选择了通过监听路由中的 id
参数,来达到在预览不同页面时候来切换开始和结束的逻辑
watch: {
$route: {
immediate: true,
handler(to, from) {
if (to.params.id) this.trainingId = to.params.id
this.startTimer()
}
}
}
调用了开始计时的方法,终于我们可以在 console
的 log
中可以看到输出了当前的时长
然后也是最后一步,我们需要在页面销毁的时候调用 stopTimer
函数来清除定时器,上报数据。
由于我们的预览页面是通过
window.open
打开的独立的标签页,所以这里是通过destroyed
生命周期函数监听。如果是通过路由方法进行的跳转,那么我们需要在离开页面的时候进行销毁,方可再通过destroyed
监听到。
mounted() {
window.addEventListener('beforeunload', e => this.beforeunloadHandler(e))
},
destroyed() {
window.removeEventListener('beforeunload', e => this.beforeunloadHandler(e))
}
通过 window
的 * 方法来来间接调用 stopTimer
方法
methods: {
beforeunloadHandler (e) {
this.stopTimer()
}
}
这里有人会问为什么不直接在 destroyed
中调用 stopTimer
方法,这样可以分离出特有的逻辑,不与 destroyed
中其它的逻辑混在一起。提高代码的可读性和维护性。
在写代码的时候我们不仅要实现功能,还要想的更多一点,这就是普通和高手的区别。
来源:https://blog.csdn.net/u013919171/article/details/118672607
猜你喜欢
- 今天继续给大家介绍渗透测试相关知识,本文主要内容是SQLMAP插件tamper编写与使用。免责声明:本文所介绍的内容仅做学习交流使用,严禁利
- 这段时间一直比较忙,一忙起来真感觉自己就只是一台挣钱的机器了(说的好像能挣到多少钱似的,呵呵);这会儿难得有点儿空闲时间,想把前段时间开发微
- 这里的内容以Linux进程基础和Linux文本流为基础。subprocess包主要功能是执行外部的命令和程序。比如说,我需要使用wget下载
- 有时候,进行了错误的提交,但是还没有push到远程分支,想要撤销本次提交,可以使用git reset –-soft/hard命令。1、二者区
- 为什么要使用多线程?使用多线程,可以同时进行多项任务,可以使用户界面更友好,还可以后台执行某些用时长的任务,同时具有易于通信的优点。pyth
- 一、绑定方法1.对象的绑定方法首先我们明确一个知识点,凡是类中的方法或函数,默认情况下都是绑定给对象使用的。下面,我们通过实例,来慢慢解析绑
- 本文实例讲述了JavaScript闭包与作用域链。分享给大家供大家参考,具体如下:闭包定义闭包指的是有权访问另一个函数作用域中的变量的函数。
- 本文实例讲述了Python实现的计算器功能。分享给大家供大家参考,具体如下:源码:# -*- coding:utf-8 -*-#! pyth
- 今天使用import pandasusers = pandas.read_csv("H:\python\data analysis
- 利用Python OpenCV中的 cv.Resize(源,目标,变换方法)就可以实现变换为想要的尺寸了源文件:就不用说了目标:你可以对图像
- 很多小伙伴对 MySQL 的隔离级别一直心存疑惑,其实这个问题一点都不难,关键看怎么讲!单纯的看理论,绝对让你晕头转向,但是,如果我们通过几
- Python 实现使用 dict 创建二维数据dict 的 keys、values 分别作为二维数据的两列In [16]: d = {1:&
- 写程序的人在编写由asp页面生成静态页面html的时候,如果同时生成大量页面,一定遇到过浏览器下方的进度条上显示着3%,6%,10%等缓慢增
- 在SQL Server 2005中,它的另外一个强大的新特点是数据库快照。数据库快照是一个数据库的只读副本,它是数据库所有数据的映射,由快照
- el-table格式化el-table-column内容遇到一个需求,一个循环展示的table中的某项,或者某几项需要格式化。对于格式化的方
- 一 引入我们学习变量是为了让计算机能够像人一样去记忆事物的某种状态,而变量的值就是用来存储事物状态的,很明显事物的状态分成不同种类的(比如人
- 使用base64对图片的二进制进行编码并用ajax进行显示有时候我们需要动态的将图片的二进制在页面上进行显示,如我们需要弄一个验证码的功能,
- Pytorch统计参数网络参数数量def get_parameter_number(net): total_num
- System.Data.OleDb.OleDbDataAdapter与System.Data.OleDb.OleDbDataReader的区
- python的format函数通过{}来格式化字符串>>> a='{0}'.format(123)>