JavaScript中实现监控切屏退出事件

一、监控是否离开页面

1、切换标签

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">

</head>
<body>
<h1>这是第一个标签页</h1>
<span>切换次数:<span id="num"></span></span>

<script>
    var  num = 0;
    document.addEventListener('visibilitychange' , () => {
        let state = document.visibilityState
        if(state == "hidden") {
            num += 1;
            // 获取要修改的span元素
            var span = document.getElementById("num");
            span.innerHTML = num;

            document.title = "你切换标签页";
        } else {
            document.title = "你又回来了";
        }
    })
</script>
</body>
</html>

2、监控是否切屏

根据MDN对state的陈述,visible部分可见也会触发,所以对于分屏监控是无法监测到的

所以需要监控另一个状态是否foucus,即是否是去当前页面的焦点

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">

</head>
<body>
<h1>这是第一个标签页</h1>
<span>切换次数:<span id="num"></span></span>

<script>
    var  num = 0;
    window.onblur = () => {
        num += 1;
        document.title = "你已切屏";
        var span = document.getElementById("num");
        span.innerHTML = num;
    }
    window.onfocus = () => {
        document.title = "你回来了";
    }
</script>
</body>
</html>

3、离开次数

不管是切屏还是离开新建标签页都需要进行计时,而且不会因为刷新而中断

由此想到sessionStorage;退出浏览器后会出现清空的情况;可以使用localStorage

// 保存数据到 sessionStorage
window.sessionStorage.setItem("key", "value");

// 从 sessionStorage 获取数据
let data = window.sessionStorage.getItem("key");

// 从 sessionStorage 删除保存的数据
window.sessionStorage.removeItem("key");

// 从 sessionStorage 删除所有保存的数据
window.sessionStorage.clear();
下面的代码片段访问了当前域名下的本地 Storage 对象,并通过 Storage.setItem() 增加了一个数据项目。

localStorage.setItem("myCat", "Tom");

语法用于读取 localStorage 项,如下:

let cat = localStorage.getItem("myCat");


该语法用于移除 localStorage 项,如下:

localStorage.removeItem("myCat");

该语法用于移除所有的 localStorage 项,如下:
// 移除所有
localStorage.clear();
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">

</head>
<body>
<h1>这是第一个标签页</h1>
<span>切换次数 sessionStorage:<span style="font-size: 28px;color: red" id="sessionStorage">1</span></span>
<br>
<span>切换次数 localStorage:<span style="font-size: 28px;color: red" id="localStoragesNum">1</span></span>

<script>
    // 清空
    // window.sessionStorage.removeItem("save_times");
    // localStorage.removeItem("save_times");

    var a = localStorage.getItem("save_times");
    var b = window.sessionStorage.getItem("save_times");
    let a1 = document.getElementById("localStoragesNum");
    let b1 = document.getElementById("sessionStorage");
    if (a1 != null){
        a1.innerHTML=a;
    }
    if(b1!=null){
        b1.innerHTML=b;
    }

    window.onblur = () => {
        document.title = "你已切屏";
        localStorages();
        countTimes();
    }
    window.onfocus = () => {
        document.title = "你回来了";
    }
    function countTimes() {
        // 关闭浏览器后自动清空次数
        // 从 sessionStorage 获取数据
        let data = window.sessionStorage.getItem("save_times");
        let span = document.getElementById("sessionStorage");
        if( data === null) {
            window.sessionStorage.setItem('save_times', 0)
            return
        }
        data ++;
        span.innerHTML=data;
        window.sessionStorage.setItem('save_times', data);
    }
    function  localStorages() {
        // 关闭浏览器后依然能够记录切屏次数
        // 从 localStorage 获取数据
        let data = localStorage.getItem("save_times");
        let localStoragesSpan = document.getElementById("localStoragesNum");
        if( data === null) {
            localStorage.setItem('save_times', 0)
            return
        }
        data ++;
        localStoragesSpan.innerHTML=data;
        localStorage.setItem('save_times', data);
    }

</script>
</body>
</html>

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值