document.visibilityState 和 visibilitychange 事件结合优化性能「建议收藏」

document.visibilityState 和 visibilitychange 事件结合优化性能「建议收藏」一般在项目中,用户登录之后有消息通知的时候,用户头像上面会有一个消息数来提醒用户,但这个数字要保证新打开一个页面的时候是正确的,当切换浏览器的tab再回来的时候还要保证正确性。说到这可能有人觉得放一个定时器,过一段时间去获取一次不就可以了,但这样会相当耗性能,使用定时器,这个页面就算被隐藏(非当前标签页、最小化)也会去一直执行这个定时器,这就相当消耗资源,而且这个页面放很久的话,还会造成页面卡死…

大家好,又见面了,我是你们的朋友全栈君。

一般在项目中,用户登录之后有消息通知的时候,用户头像上面会有一个消息数来提醒用户,但这个数字要保证新打开一个页面的时候是正确的,当切换浏览器的tab再回来的时候还要保证正确性。

说到这可能有人觉得放一个定时器,过一段时间去获取一次不就可以了,但这样会相当耗性能,使用定时器,这个页面就算被隐藏(非当前标签页、最小化)也会去一直执行这个定时器,这就相当消耗资源,而且这个页面放很久的话,还会造成页面卡死的问题。下面介绍一个方法解决这个问题。

visibilitychange

浏览器标签页被隐藏或显示的时候会触发visibilitychange事件。

document.addEventListener('visibilitychange', handleVisibilityChange, false);

要对上面的问题做优化,首先就要能够监听浏览器标签页的显示隐藏,visibilitychange事件刚好满足。现在事件可以监听到了,就要在事件中判断当前标签页是否显示,然后执行相应的事件就能解决上面的问题。

visibilityState

document.visibilityState (只读属性), 返回document的可见性,,可用的值如下:

  1. visible:页面内容可以至少部分可见。实际上,这意味着页面是非最小化窗口的前景选项卡;
  2. hidden:页面内容对用户不可见。实际上,这意味着文档可以是后台选项卡,也可以是最小化窗口的一部分,或者OS屏幕锁定处于活动状态;
  3. prerender:页面内容正在预呈现,并且对用户不可见(被视为隐藏用途document.hiddendocument.hidden只读属性,返回布尔值,表示页面是(true)否(false)隐藏))。文档可以在此状态下启动,但永远不会从另一个值转换到它。注意:浏览器支持是可选的。

实际上这里我测试了用document.visibilityStatedocument.hidden都可以达到相同的效果,但是这里https://www.w3.org/TR/page-visibility/ 推荐使用document.visibilityState

具体方案如下:

// 首次加载页面去获取设置消息数
setHeadImgBadge(); 
// 添加监听事件
document.addEventListener("visibilitychange", function () { 
   
    if (document.visibilityState == "visible") { 
    
    	//页面激活的时候再次获取设置消息数
        setHeadImgBadge();
    }
}, false);

按照上面的例子,每次新进入页面就去获取设置最新的消息数,当此页面再次被激活(用户切换到此标签页)的时候再去获取设置最新的消息数,就能保证用户看到的消息数永远是正确的了,而且不会存在定时器不断获取设置的问题,还能减轻服务器端压力。

参考:

  1. https://developer.mozilla.org/en-US/docs/Web/API/Document/visibilityState
  2. https://www.w3.org/TR/page-visibility/
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/150109.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 43w+条手机电话号码归属地数据库免费下载·附区号邮编

    43w+条手机电话号码归属地数据库免费下载·附区号邮编数据库密码已撤销天翼云盘:https://cloud.189.cn/web/share?code=VvQvuur6n2yq(访问码:r9ol)

  • springBoot注解与分析

    springBoot注解与分析springBoot注解与分析

  • 操作系统概念(Operating System Concepts Ninth Edition恐龙书)阅读

    操作系统概念(Operating System Concepts Ninth Edition恐龙书)阅读我最近在读一本操作系统的书(操作系统概念OperatingSystemConceptsNinthEdition),这本书是学习操作系统非常不错的书,只要学习过计算机组成原理、计算机体系结构、微机原理等课程就很容易读下去,虽然大多数是概念,不过课后也有编程实战题目,因此可以对操作系统有很好的把控。因此推荐给大家。大家如果看完,可以进一步看看Unix内核编程、现代操作系统的书。…

  • 使用Python对股票数据进行数据分析(一)-计算日线行情、5日均线、10日均线行情并显示

    使用Python对股票数据进行数据分析(一)-计算日线行情、5日均线、10日均线行情并显示使用Python对股票数据进行数据分析(一)-计算日线行情、5日均线、10日均线行情并显示各种炒股软件上可以显示各种技术指标,可以帮助投资者进行技术分析。这些股市中的这些指标都是怎么计算出来的呢?这里使用python的pandas库来进行计算。后期可能使用一些专门金融分析的库,比如talib库等进行分析。一、获取数据这里需要获取的数据是股票的日线行情,这里使用tushare进行获取,以…

    2022年10月26日
  • vue遍历渲染数组「建议收藏」

    vue遍历渲染数组「建议收藏」<divv-for=”iteminuserAllInfo.adevarUserSkills”:key=”item.id”>{{item}}</div>v-for=”单个数据in数组”:key=“单个数据.主键”(主键唯一)不是对象无需主键

  • 花了一个周末折腾蜗牛星际的黑群晖,多图预警!

    花了一个周末折腾蜗牛星际的黑群晖,多图预警!简介不知道什么是蜗牛星际的,可以自行百度下,顺便在引用一下矿难的前因后果:最近大量蜗牛星际二手主机在咸鱼售卖,是什么原因?总之我花了349块买了台D款的蜗牛星际J1900(有ABCD款,D款最新,也贵),买来是老板没有帮我装好黑群晖,只能自己来了。强烈建议不爱折腾或者动手能力差的,买装好系统的。不过吧,折腾起来也挺好玩的,以后系统出问题了也能自己修复。接下来我要介绍一下我安装黑群晖的过…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号