千家信息网

如何理解及使用HTML5 visibilityState属性

发表于:2025-02-24 作者:千家信息网编辑
千家信息网最后更新 2025年02月24日,本篇内容主要讲解"如何理解及使用HTML5 visibilityState属性",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"如何理解及使用HTML5 vi
千家信息网最后更新 2025年02月24日如何理解及使用HTML5 visibilityState属性

本篇内容主要讲解"如何理解及使用HTML5 visibilityState属性",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"如何理解及使用HTML5 visibilityState属性"吧!

这里必须解释一下,这个"激活",指的是这个标签是否正被用户浏览,或者说是否为当前标签。

那么,这个 API 究竟有些什么用途呢?通常,很多传统的页面在用户没有激活它的时候,它还会继续工作,例如,当用户正在浏览新闻门户,而他之前打开的 NBA 球赛页面会继续刷新获取最新结果,视频网站会继续占用带宽加载资源,于是,如果这类不必要的工作太多了,就会造成很多的资源浪费。因此,这货相当有用:

1.Web 程序每隔一段时间会自动更新页面信息,确保用户获取到及时的信息,但是,当用户正在浏览其他页面时,可以控制它暂停更新。
2.视频网站在播放在线视频时会不断加载视频,直到视频加载完毕,但是,当用户正在浏览其他页面时,可以暂停加载视频资源,节省带宽。
3.网站首页上有个大幻灯自动播放,当用户浏览其他页面了,就可以暂停播放。

于是,通过 Page Visibility ,我们可以至少达到以下一种或几种的好处:

1.节省服务器资源,Ajax 轮询这类服务器资源占用常常会被忽略,关闭这种请求可以节省资源。
2.节省内存消耗。
3.节省带宽消耗。

因此,使用 Page Visibility 无论是对于用户还是服务器都有好处。

接下来正式介绍一下这个 API 。Page Visibility 会在浏览器的 document 对象上添加两个属性 hidden 和 visibilityState 。如果当前的标签被激活了,那么 document.hidden 的值为 false ,否则为 true 。visibilityState 则有4个可能值:

1.hidden:当浏览器最小化、切换标签、电脑锁屏时 visibilityState 值是 hidden
2.visible:当浏览器最顶级上下文(context)的 document 至少显示在一个屏幕当中时,返回 visible;当浏览器窗口没有最小化,但是浏览器被其他应用遮挡时,这时也为 visible
3.prerender:当文档被加载到屏幕画面以外或者不可见时返回 prerender,这个是非必要属性,浏览器可选择性的支持。
4.unloaded:当文档将要被离开 ( unload ) 时返回 unloaded,浏览器也可选择性的支持这个属性

另外,document 上会添加 visibilitychange 事件,当 document 的可见性改变时触发该事件。

好了,介绍完属性,放上一个使用实例(保存到一个HTML文件,打开后切换标签即可测试效果)。

代码如下:





测试 HTML5 Page Visibility API




这个实例的作用是监听标签的可见性是否改变 ,并且在标签可见性发生改变时产生提示。

值得注意的是,在目前,浏览器对于 Page Visibility 的支持还是通过私有属性支持,因此在检测或利用 Page Visibility 提供的属性时需要加上浏览器私有前缀,例如在 Chrome 中检测上面的 visibilityState 属性时,就需要检测 document.webkitVisibilityState 而不是 document.visibilityState 。所以,Demo 中会首先检测浏览器类型,然后才使用 Page Visibility 的 API 。

到此,相信大家对"如何理解及使用HTML5 visibilityState属性"有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

浏览 属性 浏览器 用户 页面 标签 视频 资源 网站 支持 检测 带宽 服务器 正在 激活 服务 最小 事件 信息 内容 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 国家网络安全法新规定 网络安全靶场有哪些平台 长沙信息管理系统软件开发 百度校招软件开发工资 我的世界怎么给服务器做充值系统 杭州银行子公司软件开发 云服务器路由管理器 SCIE是全文型数据库吗 简述互联网软件开发 龙口微信小程序软件开发外包公司 世纪英梵东莞网络技术有限公司 网络安全人员资质情况 路由器交换机网关服务器 网络技术转让合同模板 保定市豆荚网络技术有限公司 维也纳网络安全吗 手机如何开服务器 3d建模软件开发公司 服务器上市公司 H股 延庆区信息化软件开发创新服务 计算机网络技术 计算机应用 网络安全和信息化安全落实 360网络安全风险 软件开发属于电子与智能化范围吗 传奇一区二区最开始有几个服务器 关于阿里云esc云服务器的体验 web服务器的管理与建立 网络安全重视 第一观点网络技术 网络技术部岗位说明书
0