利用 Page Visibility API 优化网页性能与用户体验
在现代 Web 开发中,用户可能会频繁切换标签页,或让网页处于后台运行。为了避免不必要的资源浪费并提升用户体验,合理利用 Page Visibility API 可以在页面不可见时暂停或减少资源的消耗,并在页面重新可见时恢复正常操作。
在这篇博客中,我将展示如何通过 Page Visibility API 实现以下场景:
- 当用户切换标签页时暂停视频或音频播放。
- 当页面不可见时停止资源密集型的动画。
- 页面不可见时停止 API 请求,并在页面可见时重新开始。
- 当用户返回页面时恢复定时操作。
什么是 Page Visibility API?
Page Visibility API 是一个浏览器提供的 API,它可以告诉我们页面的可见性状态。当页面变为不可见时,我们可以暂停一些不必要的操作,比如动画或媒体播放。这个 API 提供了两个核心功能:
document.hidden:返回一个布尔值,指示页面当前是否隐藏。document.visibilityState:返回页面的可见性状态,可以是'visible'(页面可见)、'hidden'(页面隐藏)或'prerender'(页面正在预渲染)。visibilitychange事件:当页面的可见性状态(document.visibilityState)改变时触发。
visibilityState 的作用
document.visibilityState 提供比 document.hidden 更直观的信息。它不仅告诉你页面是否隐藏,还能进一步区分页面是否正在预渲染。例如,你可以根据不同的状态采取不同的优化措施。
浏览器兼容性
虽然 Page Visibility API 很有用,但它的兼容性在不同浏览器中略有差异。以下是各主流浏览器的支持情况:
Document.hidden 和 document.visibilityState
| 浏览器 | 支持情况 | 版本 |
|---|---|---|
| Chrome | 支持 | 自 33 版本起 |
| Firefox | 支持 | 自 18 版本起 |
| Safari | 支持 | 自 7 版本起 |
| Edge | 支持 | 自 12 版本起 |
| Opera | 支持 | 自 20 版本起 |
visibilitychange 事件
| 浏览器 | 支持情况 | 版本 |
|---|---|---|
| Chrome | 支持 | 自 62 版本起 |
| Firefox | 支持 | 自 56 版本起 |
| Safari | 支持 | 自 14.1 版本起 |
| Edge | 支持 | 自 18 版本起 |
| Opera | 支持 | 自 49 版本起 |
用户切换标签页时暂停视频播放
当用户切换标签页时,继续播放视频会浪费带宽和资源。通过 Page Visibility API,可以在页面不可见时暂停视频,等用户返回后再自动恢复播放。
const videoElement = document.querySelector("video");
document.addEventListener("visibilitychange", function() {
if (document.visibilityState === 'hidden') {
// 页面隐藏时暂停视频
videoElement.pause();
console.log("页面隐藏,视频暂停");
} else if (document.visibilityState === 'visible') {
// 页面可见时恢复视频播放
videoElement.play();
console.log("页面可见,视频继续播放");
}
});
页面不可见时停止资源密集型动画
动画可能是性能瓶颈,尤其是在页面不可见时运行动画毫无意义。通过 Page Visibility API,我们可以在页面不可见时暂停动画,减少 CPU 和 GPU 的消耗。
let animationRunning = true;
function startAnimation() {
if (!animationRunning) return;
// 假设这里有动画逻辑
console.log("动画正在运行...");
requestAnimationFrame(startAnimation);
}
document.addEventListener("visibilitychange", function() {
if (document.visibilityState === 'hidden') {
// 页面隐藏时停止动画
animationRunning = false;
console.log("页面隐藏,动画停止");
} else if (document.visibilityState === 'visible') {
// 页面可见时恢复动画
animationRunning = true;
startAnimation();
console.log("页面可见,动画恢复");
}
});
startAnimation();
页面不可见时停止 API 请求
某些情况下,持续的数据获取可能会浪费带宽。通过检测页面的可见性,可以在页面不可见时停止数据请求,优化带宽使用。
let requestInterval;
function startFetchingData() {
requestInterval = setInterval(() => {
// 模拟 API 请求
console.log("正在获取数据...");
}, 5000);
}
function stopFetchingData() {
clearInterval(requestInterval);
console.log("停止获取数据");
}
document.addEventListener("visibilitychange", function() {
if (document.visibilityState === 'hidden') {
// 页面隐藏时停止数据获取
stopFetchingData();
} else if (document.visibilityState === 'visible') {
// 页面可见时恢复数据获取
startFetchingData();
}
});
startFetchingData();
页面可见时恢复定时操作
当页面不可见时,某些定时任务可以暂停,直到用户返回页面时再恢复执行。这有助于提升资源利用效率。
let intervalId;
function startTimer() {
intervalId = setInterval(() => {
console.log("计时器正在运行...");
}, 1000);
}
function stopTimer() {
clearInterval(intervalId);
console.log("计时器停止");
}
document.addEventListener("visibilitychange", function() {
if (document.visibilityState === 'hidden') {
// 页面隐藏时停止计时器
stopTimer();
} else if (document.visibilityState === 'visible') {
// 页面可见时恢复计时器
startTimer();
}
});
startTimer();
用户返回页面时恢复音频播放
与视频类似,音频在页面不可见时继续播放不仅对用户无意义,还会浪费系统资源。通过 Page Visibility API 可以在用户返回页面时恢复音频播放。
const audioElement = document.querySelector("audio");
document.addEventListener("visibilitychange", function() {
if (document.visibilityState === 'hidden') {
// 页面隐藏时暂停音频
audioElement.pause();
console.log("页面隐藏,音频暂停");
} else if (document.visibilityState === 'visible') {
// 页面可见时恢复音频播放
audioElement.play();
console.log("页面可见,音频继续播放");
}
});
结论
Page Visibility API 是一个简单但非常有效的工具,能够让开发者根据页面的可见性来动态优化资源的使用。结合 document.visibilityState,你可以进一步细化页面状态的控制,如在页面预渲染时暂停某些操作。
这种优化不仅提升了用户体验,还能显著减少系统资源的浪费。通过合理利用这个 API,我们可以暂停后台的视频、音频、动画、数据请求等操作,并在用户重新关注页面时迅速恢复,达到性能和体验的双重提升。
在开发过程中,别忘了考虑浏览器的兼容性问题,确保在所有平台上提供一致的用户体验。希望这篇文章能够帮助你更好地掌握 Page Visibility API 并将其应用到实际项目中。
参考内容
- 页面可见性 API - Web API | MDN (mozilla.org)
- Document:visibilitychange 事件 - Web API | MDN (mozilla.org)
- Document:hidden 属性 - Web API | MDN (mozilla.org)
- Document.visibilityState - Web API | MDN (mozilla.org)
利用 Page Visibility API 优化网页性能与用户体验的更多相关文章
- 妙趣横生的HTML5 Page Visibility API
起因 最近浏览36kr 的网页的时候偶然发现一个有趣的情况:当浏览器Tab 处于非当前页的时候,36kr 的标题栏会自动换成可爱的大白字符形象.Jeff 在第一次看到的时候就知道这种效果是通过HTML ...
- H5的Page Visibility API
概述 哈哈,又学了一个H5的API.今天突然对动态获取网页的选中状态很感兴趣,然后去查了下,发现真的有个API控制它--Page Visibility API.于是把学到的东西记录下来,供以后开发时参 ...
- Page Visibility API
在code review时看见同事使用visibilitychange 事件来监听页面的隐藏与显示,之前没有了解过这块,学习一下. document.visibilityState 主要有以下3个状态 ...
- 【学而思】利用shouldComponentUpdate钩子函数优化react性能以及引入immutable库的必要性
凡是参阅过react官方英文文档的童鞋大体上都能知道对于一个组件来说,其state的改变(调用this.setState()方法)以及从父组件接受的props发生变化时,会导致组件重渲染,正所谓&qu ...
- 【react】利用shouldComponentUpdate钩子函数优化react性能以及引入immutable库的必要性
凡是参阅过react官方英文文档的童鞋大体上都能知道对于一个组件来说,其state的改变(调用this.setState()方法)以及从父组件接受的props发生变化时,会导致组件重渲染,正所谓&qu ...
- vue-使用keep-alive优化网页性能
export default{ name: 'Home', data () { return { iconList: [], recommendList: [], swiperList: [], we ...
- 利用表达式树Expression优化反射性能
最近做了一个.Net Core环境下,基于NPOI的Excel导入导出以及Word操作的服务封装,涉及到大量反射操作,在性能优化过程中使用到了表达式树,记录一下. Excel导入是相对比较麻烦的一块, ...
- 利用图片延迟加载来优化页面性能(jQuery)
图片延迟加载也称懒加载,常用于页面很长,图片很多的页面,以电子商务网站居多,比如大家常上的京东,淘宝,页面以图居多,整个页面少说几百K,多则上兆,如果想一次性加载完成,不仅用户要哭了,服务器也得哭了. ...
- Page Visibility API(页面可见性)
页面可见性: 就是对于用户来说,页面是显示还是隐藏, 所谓显示的页面,就是我们正在看的页面:隐藏的页面,就是我们没有看的页面. 因为,我们一次可以打开好多标签页面来回切换着,始终只有一个页面在我们眼前 ...
- Page Visibility API 页面是否获取焦点 Event: visibilitychange
W3C 文档 https://www.w3.org/TR/page-visibility/ MDN 文档 https://www.w3.org/TR/page-visibility/ // Docum ...
随机推荐
- P10245 Swimming Pool题解
P10245 Swimming Pool 题意 给你四条边 \(abcd\),求这四条边是否可以组成梯形. 思路 这显然是一道简单的普通数学题. 判断是否能构成梯形只需看四条边是否能满足,上底减下底的 ...
- 关于使用UE5打包Android的测试
UE5打包Android,不同于UE4,在官方文档中需要Android studio 4.0或者3.5,还有Android SDK,NDK等 设置SetupAndroid, 在UE5 Editor配置 ...
- iOS开发基础143-性能优化
我们可以先构建一个详细的大纲,然后在每个部分详细阐述.下面是一个针对iOS性能优化的详细大纲: 一. App启动时间优化 A. 启动分类 冷启动 热启动 B. 冷启动优化 减少启动时的动态库加载 尽可 ...
- jwt redis,微信登陆知识复习 uniapp 请求封装,统一异常处理 相关, HutoolDemo工具介绍)
第三节 后台布局搭建,代码可以人工智能来写,但是环境初步搭建需要我们先建起来,所以以下记录快带搭建的过程, 思路: 后台首页的搭建 第一 用到了element--UI 自带的页面布局组件,它就 ...
- (2024最新)有效解决OpenAI Chatgpt Plus升级报错【您的银行卡被拒绝了/your card has been declined」,不用再问怎么办?
在OpenAI升级ChatGPT plus时我们可能会遇到升级报错[您的银行卡被拒绝了/your card has been declined」,有些人看到这个可能就会不知所措 注意,这个问题目前依旧 ...
- 【H5】03 文本内容处理
摘自: https://developer.mozilla.org/zh-CN/docs/Learn/HTML/Introduction_to_HTML/HTML_text_fundamentals ...
- 【Java】Socket Programming 网络编程
Java提供了网路相关的类库,无痛连网,底层细节交给JVM控制 Java实现了一个跨平台的网络库,我们开发面对的是一个统一的网路编程环境 目的: 直接或者间接的通过网络协议和其他计算机数据交互,通讯 ...
- jmeter 使用非 GUI 模式运行测试脚本
使用非 GUI 模式运行测试脚本时可以使用的一些命令:-h 帮助 -> 打印出有用的信息并退出-n 非 GUI 模式 -> 在非 GUI 模式下运行 JMeter-t 测试文件 -> ...
- 编程语言中的Variable Shadowing(变量遮蔽)—— declaration shadows a local variable —— Consider Allow Shadowing of let Bindings
Variable Shadowing(变量遮蔽)是编程语言中比较常见的一种情况,但是由于不同语言对于这个情景的处理是不同的,所以在具体语言中这个Variable Shadowing(变量遮蔽)的表现也 ...
- H5页面\PC端实现QQ客服功能
1.背景 很多应用都有在线客服,最简单是实现就是利用人们常用的QQ 2.实现 步骤一:授权QQ通讯组件(普通QQ都是可以的) 授权链接:https://shang.qq.com/v3/widget.h ...