`

html5新特性介绍之PageVisibility API

阅读更多
   在HTML5的众多新特性中,有的新特性可能容易被人忽视,又或者不是主流新
特性,但不可忽略,因为估计以后越来越多浏览器支持.今天要介绍的,就是
chrome和ie 10都支持的一个很好的新特性:HTML5中的PageVisibility API,下面例
子讲解下.
   比如在web中,有的时候,用户会经常切换页面,把某个页面最小化后,可能很久时间都不打开某个页面了,要过很久再打开.又或者比如在浏览器中,会打开很多TAB同时,有时WEB应用
甚至想清楚了解用户究竟打开某个页看了多长时间,这个在以往,可能很难去做到(特别是判断
用户最小化或者切换了其他页的TAB).但现在HTML5中,提出了相关的规范API,叫
pagevisibility api,其WC3的规范在如下连接可以找到描述:
http://dvcs.w3.org/hg/webperf/raw-file/tip/specs/PageVisibility/Overview.html
   其中,DocumentVisibility是其接口,有两个属性:document.hidden和
document.visibilityState.
1)document.hidden属性:
     当用户隐藏了页面或者最小化时,该属性返回true
2)document.visibilityState
    返回当前页面的状态,分别为hidden(隐藏不可见),visiable(可见),preview(标准中认为是可选的,暂时没浏览器实现).
    我们先来看个具体的例子,请用chrome去浏览:http://www.samdutton.com/pageVisibility/
    这里例子中,当你新增加了一个TAB时,会发现音乐和动画停止了,当你再次切换回去
时,动画又会继续了,是不是很有趣呢?

     再来看具体的例子,代码如下:
<!DOCTYPE HTML>  
<html>  
<head>  
     <script type="text/javascript">  
          timer = 0;  
          function onLoad(){  
               document.addEventListener("visibilitychange",stateChanged);  
               document.addEventListener("webkitvisibilitychange", stateChanged);  
               document.addEventListener("msvisibilitychange", stateChanged);  
          }  
          function stateChanged(){  
               console.log(document.webkitVisibilityState);  
               if(document.hidden || document.webkitHidden || document.msHidden){  
                    //new tab or window minimized
                    timer = new Date().getTime();  
               }  
               else {  
                    alert('You were away for ' + (new Date().getTime()-timer)/1000+ ' seconds.')  
               }  
          }  
     </script>  
</head>  
<body onLoad="onLoad()">  
</body>  
</html>

    在上面的代码中,同样,在CHROME运行下,在LOAD事件中,监听了相关的
webkitvisibilitychange事件(这个在CHROME下),如果是IE 10,则是
msvisibilitychange事件,然后在回调函数中,开始了计算用户在页面停留的时间,
所以当你打开其他TAB页或者最小化后,再切换回原来这个页,则会JAVASCRIPT
弹出显示:你离开了页面多长时间
    要注意的是,在CHROME中,属性命名为webkitHidden,事件为 webkitvisibilitychange事件,而在IE 10中,属性为msHidden 和
msVisibilityState.
   参考资料:http://blogs.msdn.com/b/ie/archive/2011/07/08/using-pc-hardware-more-efficiently-in-html5-new-web-performance-apis-part-2.aspx
    http://code.google.com/chrome/whitepapers/pagevisibility.html
3
0
分享到:
评论

相关推荐

    HTML5实现页面切换激活的PageVisibility API使用初探

    PageVisibility API 是HTML5提供的一种用于检测网页可见状态的接口,它可以帮助开发者更有效地管理页面资源,提升用户体验,同时减少服务器负担和用户设备的资源消耗。API的核心在于两个关键属性和一个事件: 1. `...

    5月最新大厂前端高频核心面试题.pdf

    HTML5是目前前端开发中使用最为广泛的技术之一,它的新特性提供了更多的功能和元素,用以丰富网页的结构和表现。HTML5移除了诸如、、等一些不常用的元素,同时引入了诸如、、等新的语义化标签。区分HTML和HTML5通常...

    shooting-at-balls:伪装成 WebGL 射击游戏的 HTML5 API 测试场

    哦,这是一款使用大量 HTML5 API 的 WebGL 射击风格游戏。 来吧,现在就在这里射球: : #Credits 本实验使用 、 、 和 。 它是项目的后代,但它还具有 Ascent 中不存在的元素,例如 InfiniteGround、WebAudio ...

    HTML5 visibilityState属性详细介绍和使用实例

    HTML5的visibilityState属性是一个特别的API,它能够检测当前浏览器标签页是否处于激活状态。这种状态指的是标签页是否正被用户查看或使用,即是否处于当前焦点。这个功能虽然平时很少有人注意,但它却能在很多场景...

    前端面试题大全

    页面可见性(PageVisibility)API允许开发者了解页面是否在用户视图中,并根据该状态执行相应的操作,如暂停播放音乐或视频,从而优化页面性能和用户体验。 关于布局,CSS的min-height属性使得div元素在内容不足时...

    react-page-visibility-render-props:用于pagevisibility.js包的简单React包装器呈现道具以实现更好的可组合性

    只需将函数作为&lt;PageVisibility&gt;组件的&lt;PageVisibility&gt; 。 此函数应具有单个参数,该参数可以visible | hidden | prerender visible | hidden | prerender visible | hidden | prerender (请查看完整说明)。 ...

    jquery.pagevisibility:浏览器之间的页面可见性标准化

    jquery.pagevisibility 该插件规范了页面可见性 API 的前缀名称,以便您可以简单地使用带有 jQ​​uery 的无前缀的“visibilitychange”事件并使用无前缀的 document.hidden 和 document.visibilityState 属性。 ...

    前端面试题

    **07、html5有哪些新特性、移除了那些元素?如何处理HTML5新标签的浏览器兼容问题?** - **新特性**:包括语义化标签(如`&lt;article&gt;`, `&lt;section&gt;`, `&lt;header&gt;`)、多媒体支持(`&lt;video&gt;`, `&lt;audio&gt;`)、离线存储、...

    page-visibility:页面可见性API包装器和Polyfill

    page-visibility.js 包装器这个小包装器隐藏了供应商前缀,并为浏览器中的可见性API提供了有用的高级API。 几乎所有浏览器都原生Page Visibility API。 对于旧的浏览器,使用焦点/模糊技巧(请注意,当浏览器失去...

    web前端笔试面试

    HTML5的新特性、移除的元素及处理兼容性问题?** - **新特性**: 新增语义化标签(如`&lt;header&gt;`, `&lt;nav&gt;`)、多媒体标签(如`&lt;video&gt;`, `&lt;audio&gt;`)等。 - **移除元素**: `frame`, `frameset`, `acronym`等。 - **...

    page-visibility:页面可见度

    虽然大部分现代浏览器支持页面可见性API,但为了确保跨浏览器的兼容性,应该使用`window.PageVisibility_API`进行检测,如: ```javascript if ('hidden' in document) { // 支持页面可见性API } ``` 同时,注意...

    使用C#在注册表中保存信息的例子

    本文将详细介绍如何在C#中操作注册表来保存和读取程序的用户设置。 首先,C#中与注册表交互的操作主要通过Microsoft.Win32命名空间下的Registry类来实现。在上述代码中,首先定义了一个名为RegistryStorage的公共...

    analytics:不要用这个。 你为什么要? 只是不要

    3. **利用浏览器原生API**:例如`eventTracker`、`pageVisibility`等,它们可以实现基本的用户行为追踪。 4. **评估替代库**:寻找评价好、维护活跃且与项目需求匹配的分析库,如Amplitude、Mixpanel等。 5. **...

    re-use::atom_symbol::fishing_pole:ReasonReact的钩子集合

    @ lxsmnsyc /重复使用 :atom_symbol: :fishing_pole: 一组ReasonReact的钩子 ... PageVisibility 以前的 承诺 RefMounted 同步效果 节流减速器 节流状态 更新效果 窗口大小 执照 麻省理工学院:copyright:

Global site tag (gtag.js) - Google Analytics