前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >当前页面是否可见

当前页面是否可见

作者头像
公众号@魔术师卡颂
发布2020-08-26 09:44:07
发布2020-08-26 09:44:07
2K00
代码可运行
举报
文章被收录于专栏:魔术师卡颂魔术师卡颂
运行总次数:0
代码可运行

判断当前页面是否可见。


使用Document.hidden属性判断当前页面是否可见。

代码语言:javascript
代码运行次数:0
运行
复制
const isBrowserTabFocused = () => !document.hidden;

例子

代码语言:javascript
代码运行次数:0
运行
复制
// true
isBrowserTabFocused(); 

扩展阅读

Document.hidden属性来自于浏览器Page Visibility API

API的设计目的是为了方便开发者监听页面的可见性的变化,包括如下组成部分:

Document.hidden

为一个只读布尔值,表示当前页面是否被可见。

document.visibilityState

为一个只读字符串,表示页面当前的可见性状态,共有三个可选值:

  • hidden:页面不可见
  • visible:页面部分可见
  • prerender:页面即将或正在渲染,处于不可见状态

当满足如下条件之一,为hidden

  • 浏览器窗口最小化
  • 当前浏览器Tab未处于激活状态
  • 浏览器将要卸载(unload)页面
  • 移动端设备触发触发锁屏

除此之外,页面露出任何部分都属于visible

prerender存在于支持预渲染的浏览器。可以在用户不可见的状态下,预先把页面渲染出来,等到用户要浏览的时候,直接展示渲染好的网页。

visibilitychange事件

document.visibilityState属性发生变化会触发visibilitychange事件。

代码语言:javascript
代码运行次数:0
运行
复制
document.addEventListener('visibilitychange', function () {
  if (document.visibilityState === 'hidden') {
    console.log('当前页面不可见');
  }

  if (document.visibilityState === 'visible') {
    console.log('当前页面可见');
  }
});
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2020-07-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 魔术师卡颂 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 例子
  • 扩展阅读
    • Document.hidden
    • document.visibilityState
    • visibilitychange事件
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档