js 统计用户停留网站时长

统计用户停留网站时长

统计用户时长的意义和一些思路说明

应用场景可以是统计手机App使用时长、统计用户打开网站后多久会关闭,这都是属于大数据的范畴。

由此可以拓展到用户使用每个页面的浏览时长,统计每个页面浏览时长可以更好的统计哪些页面是用户经常浏览,

从而更好的优化这些页面,而浏览量比较少的或者没有浏览量的页面应该重新设计或者花更少时间去维护。

而在前端方面存储这些数据的实现思路总体是差不多的。

当然上面的方法也有一定的缺点,比如数据可能会丢失、每个打开的页面都要启动一个定时器等等。

如果需要数据更精准些,我们可以使用websocket或者启动一个定时器定时向后台传数据等等,这样会也有一点的缺点,比如增大服务器压力,影响性能。

具体实现方式

js 复制代码
// 进入页面 - load
window.addEventListener("load",function(){
    let nowTime = getNowTime()
    let openPageCount = localStorage.getItem("openPageCount")
    openPageCount = openPageCount ? parseInt(openPageCount) : 0
    openPageCount += 1
    localStorage.setItem("openPageCount",openPageCount)
    // 用户意外关掉电脑或者突然断电了,这时候是不会执行beforeunload是不会执行
    refreshTime()
    let isRightTime =  compareRefreshTime()
    //其实说明是页面是刷新后加载的,不需要统计开始时间
    if(sessionStorage.getItem("flag") && isRightTime){
        return;
    }
    localStorage.setItem("startTime",nowTime)
    localStorage.setItem("refreshTime",nowTime)
    sessionStorage.setItem("flag", true);
})

// 浏览器关闭 - beforeunload
window.addEventListener("beforeunload",function(){
    let nowTime = getNowTime()
    let openPageCount = localStorage.getItem("openPageCount")
    openPageCount -= 1
    localStorage.setItem("endTime",nowTime)
    localStorage.setItem("openPageCount",openPageCount)
    if(openPageCount == 0){
        //说明页面全部关闭,这时候可以传数据给后台
    }
})

function getNowTime(){
    let nowTime = new Date().getTime()
    return nowTime
}

function compareRefreshTime(){
   let nowTime = getNowTime()
   let refreshTime = localStorage.getItem("refreshTime")
   return nowTime - refreshTime < 60 * 1000
}
// 可以往localStorage里存一个刷新时间,每30秒更新这个刷新时间
// 用户加载网站时,读取这个刷新时间,如果当前时间和这个刷新时间相差大于1分钟,说明数据有断层,此时应该抛弃这一条记录数据
function refreshTime(){
    // 避免意外关机导致数据统计丢失问题
    setTimeout(refreshTime ,30 * 1000)
    let nowTime = getNowTime()
    localStorage.setItem("refreshTime",nowTime)
}

其实这种直接在后台java统计也是可以的,以上只是js的实现方式。

相关推荐
渣渣苏1 分钟前
Java后端接入大模型API的坑
java·开发语言
胖咕噜的稞达鸭2 分钟前
库的原理和制作 动态库如何和可执行程序相关联,为什么程序入口点不是main函数,GOT表,PIC地址无关代码(2)
linux·c语言·开发语言·网络
予枫的编程笔记3 分钟前
深度剖析 HashMap:从 JDK 1.7 死循环到 1.8 高低位映射优化
java·开发语言·散列表·hashmap
窗边鸟5 分钟前
小白日记之二维数组(java学习)
java·开发语言·学习
报错小能手5 分钟前
线程池学习(五) 单线程池(SingleThreadPool)
开发语言
缺点内向6 分钟前
报表自动化进阶:Java精确操控Excel打印页边距的实战方法
java·开发语言·后端·自动化·excel
特严赤傲8 分钟前
H5 页面在微信浏览器里调用微信支付 demo
javascript·微信·jsapi
凌晨一点的秃头猪11 分钟前
KERAG_R详细分析:
开发语言
2301_7973122611 分钟前
学习Java36天
java·开发语言·学习
studytosky12 分钟前
Linux系统编程:深度解析 Linux 进程,切换调度、环境变量与虚拟内存
linux·运维·服务器·开发语言·网络·c++