- 浏览: 7936050 次
- 性别:
- 来自: 广州
文章分类
- 全部博客 (2425)
- 软件工程 (75)
- JAVA相关 (662)
- ajax/web相关 (351)
- 数据库相关/oracle (218)
- PHP (147)
- UNIX/LINUX/FREEBSD/solaris (118)
- 音乐探讨 (1)
- 闲话 (11)
- 网络安全等 (21)
- .NET (153)
- ROR和GOG (10)
- [网站分类]4.其他技术区 (181)
- 算法等 (7)
- [随笔分类]SOA (8)
- 收藏区 (71)
- 金融证券 (4)
- [网站分类]5.企业信息化 (3)
- c&c++学习 (1)
- 读书区 (11)
- 其它 (10)
- 收藏夹 (1)
- 设计模式 (1)
- FLEX (14)
- Android (98)
- 软件工程心理学系列 (4)
- HTML5 (6)
- C/C++ (0)
- 数据结构 (0)
- 书评 (3)
- python (17)
- NOSQL (10)
- MYSQL (85)
- java之各类测试 (18)
- nodejs (1)
- JAVA (1)
- neo4j (3)
- VUE (4)
- docker相关 (1)
最新评论
-
xiaobadi:
jacky~~~~~~~~~
推荐两个不错的mybatis GUI生成工具 -
masuweng:
(转)JAVA获得机器码的实现 -
albert0707:
有些扩展名为null
java 7中可以判断文件的contenttype了 -
albert0707:
非常感谢!!!!!!!!!
java 7中可以判断文件的contenttype了 -
zhangle:
https://zhuban.me竹板共享 - 高效便捷的文档 ...
一个不错的网络白板工具
在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时,会发现音乐和动画停止了,当你再次切换回去
时,动画又会继续了,是不是很有趣呢?
再来看具体的例子,代码如下:
在上面的代码中,同样,在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
特性,但不可忽略,因为估计以后越来越多浏览器支持.今天要介绍的,就是
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
发表评论
-
微信开发工具中时间问题的小坑
2018-02-07 19:07 816刚开始用微信小程序开发工具,每次运行任何应用,都报这个错误: ... -
三篇不错的介绍CSS GRID的文章
2017-12-06 09:08 533三篇不错的介绍CSS GRID的文章: http://www. ... -
双因素认证(2FA)教程
2017-11-03 09:16 1570http://www.ruanyifeng.com/blog/ ... -
es6 中的export
2017-08-20 08:00 814https://juejin.im/post/5998625f ... -
markdown中的空格
2017-08-20 07:53 1694即使手动输入空格, 也是很不推荐的方法。我推荐全角空格,切换 ... -
(转)讲真,别再使用JWT了
2017-08-17 23:21 1007不错的好文: http://insights.thoughtw ... -
(转)手把手教你WebStorm+chrome实现时时调试刷新
2017-08-15 10:50 3019参考: http://jingyan.baidu.com/ar ... -
IntelliJ Idea 2017 免费激活方法
2017-08-15 09:38 93121. 到网站 http://idea.lanyus.com/ ... -
前端框架这么多,该何去何从?
2017-08-04 07:17 645http://insights.thoughtworkers. ... -
记录一个HTML 5画拓扑图的商业公司
2017-07-18 19:56 844http://qunee.com/ DEMO:http:// ... -
vue 2例子学习收集
2017-07-16 11:46 9981 vue2.0手撸闲鱼App https://githu ... -
(收藏)虚拟DOM内部是如何工作的
2017-07-13 22:08 588虚拟DOM内部是如何工作的 https://segmentfa ... -
最近看到的几篇精彩JAVASCRIPT博客文章推荐
2017-07-11 07:10 562【深度长文】JavaScript数组所有API全解密 http ... -
jsonp 跨域原理:深入浅出 jsonp
2017-07-10 19:55 1427https://lzw.me/a/jsonp.html jso ... -
(转)深度长文-JavaScript数组所有API全解密
2017-07-08 19:59 817深度长文-JavaScript数组所有API全解密 http: ... -
(收藏)网页导出PDF的方案
2017-07-06 07:13 960(收藏)网页导出PDF的方案 https://yiqiwuli ... -
Chromium 新的弹窗机制以及 HTML 的 <dialog> 元素
2017-06-28 12:37 1144https://juejin.im/post/59525195 ... -
国内一个不错的大屏UI设计厂家
2017-06-03 19:43 3156http://www.lanlanwork.com/dp.ph ... -
canvas仿芝麻信用分仪表盘
2017-05-28 20:21 1584canvas仿芝麻信用分仪表盘 https://segment ... -
(转)CSS 变量教程
2017-05-10 21:12 573http://www.ruanyifeng.com/blog/ ...
相关推荐
PageVisibility API 是HTML5提供的一种用于检测网页可见状态的接口,它可以帮助开发者更有效地管理页面资源,提升用户体验,同时减少服务器负担和用户设备的资源消耗。API的核心在于两个关键属性和一个事件: 1. `...
HTML5是目前前端开发中使用最为广泛的技术之一,它的新特性提供了更多的功能和元素,用以丰富网页的结构和表现。HTML5移除了诸如、、等一些不常用的元素,同时引入了诸如、、等新的语义化标签。区分HTML和HTML5通常...
哦,这是一款使用大量 HTML5 API 的 WebGL 射击风格游戏。 来吧,现在就在这里射球: : #Credits 本实验使用 、 、 和 。 它是项目的后代,但它还具有 Ascent 中不存在的元素,例如 InfiniteGround、WebAudio ...
HTML5的visibilityState属性是一个特别的API,它能够检测当前浏览器标签页是否处于激活状态。这种状态指的是标签页是否正被用户查看或使用,即是否处于当前焦点。这个功能虽然平时很少有人注意,但它却能在很多场景...
页面可见性(PageVisibility)API允许开发者了解页面是否在用户视图中,并根据该状态执行相应的操作,如暂停播放音乐或视频,从而优化页面性能和用户体验。 关于布局,CSS的min-height属性使得div元素在内容不足时...
只需将函数作为<PageVisibility>组件的<PageVisibility> 。 此函数应具有单个参数,该参数可以visible | hidden | prerender visible | hidden | prerender visible | hidden | prerender (请查看完整说明)。 ...
jquery.pagevisibility 该插件规范了页面可见性 API 的前缀名称,以便您可以简单地使用带有 jQuery 的无前缀的“visibilitychange”事件并使用无前缀的 document.hidden 和 document.visibilityState 属性。 ...
**07、html5有哪些新特性、移除了那些元素?如何处理HTML5新标签的浏览器兼容问题?** - **新特性**:包括语义化标签(如`<article>`, `<section>`, `<header>`)、多媒体支持(`<video>`, `<audio>`)、离线存储、...
page-visibility.js 包装器这个小包装器隐藏了供应商前缀,并为浏览器中的可见性API提供了有用的高级API。 几乎所有浏览器都原生Page Visibility API。 对于旧的浏览器,使用焦点/模糊技巧(请注意,当浏览器失去...
HTML5的新特性、移除的元素及处理兼容性问题?** - **新特性**: 新增语义化标签(如`<header>`, `<nav>`)、多媒体标签(如`<video>`, `<audio>`)等。 - **移除元素**: `frame`, `frameset`, `acronym`等。 - **...
虽然大部分现代浏览器支持页面可见性API,但为了确保跨浏览器的兼容性,应该使用`window.PageVisibility_API`进行检测,如: ```javascript if ('hidden' in document) { // 支持页面可见性API } ``` 同时,注意...
本文将详细介绍如何在C#中操作注册表来保存和读取程序的用户设置。 首先,C#中与注册表交互的操作主要通过Microsoft.Win32命名空间下的Registry类来实现。在上述代码中,首先定义了一个名为RegistryStorage的公共...
3. **利用浏览器原生API**:例如`eventTracker`、`pageVisibility`等,它们可以实现基本的用户行为追踪。 4. **评估替代库**:寻找评价好、维护活跃且与项目需求匹配的分析库,如Amplitude、Mixpanel等。 5. **...
@ lxsmnsyc /重复使用 :atom_symbol: :fishing_pole: 一组ReasonReact的钩子 ... PageVisibility 以前的 承诺 RefMounted 同步效果 节流减速器 节流状态 更新效果 窗口大小 执照 麻省理工学院:copyright: