PC 端页面显示与隐藏

预计阅读时间: 小于 1 分钟

1、业务需求:

  PC 端直播,为了统计用户观看的有效时长,对观看直播的规则做了一些要求,目的是为了提高用户的有效观看时长。

具体要求如下

  1. 浏览器页面最小化时,暂停播放,停止计时;
  2. 浏览器页面恢复时,视频继续播放,计时从零开始;
  3. 刷新浏览器页面时,重新计时;

2、页面显示与隐藏

使用的是浏览器的 visibilityState 属性:

页面显示与隐藏
1// 页面的显示与隐藏
2const pageShowOrHide = function (e) {
3	let stv = e.target.visibilityState || document.visibilityState;
4	if (stv === "hidden") {
5		// 用户最小化了页面 or 切到了别的页面
6		/* 处理页面隐藏事件代码 */
7	} else if (stv === "visible") {
8		// 用户回到了页面
9		/* 处理页面恢复事件代码 */
10	}
11};

绑定&解除事件函数

事件监听
1// 绑定事件函数
2window.addEventListener(
3	"visibilitychange",
4	function () {
5		pageShowOrHide();
6	},
7	false
8);
9
10window.addEventListener("visibilitychange", pageShowOrHide());
11
12// 解除事件函数
13window.removeEventListener(
14	"visibilitychange",
15	function () {
16		pageShowOrHide();
17	},
18	false
19);
20
21window.removeEventListener("visibilitychange", pageShowOrHide());

false:是否冒泡

3、刷新页面(页面卸载)

刷新页面
1window.addEventListener(
2	"beforeunload",
3	function () {
4		/* 执行页面卸载前的事件代码 */
5	},
6	false
7);
8
9window.removeEventListener("beforeunload", function () {}, false);
10
11// or
12window.addEventListener("beforeunload", function () {
13	/* 执行页面卸载前的事件代码 */
14});
15
16window.removeEventListener("beforeunload", function () {});