切换标签页自动暂停视频

当从含有视频的标签页切换到其他标签页时,视频自动暂停播放。

您需要先安裝使用者腳本管理器擴展,如 TampermonkeyGreasemonkeyViolentmonkey 之後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyUserscripts 後才能安裝該腳本。

你需要先安裝一款使用者腳本管理器擴展,比如 Tampermonkey,才能安裝此腳本

您需要先安裝使用者腳本管理器擴充功能後才能安裝該腳本。

(我已經安裝了使用者腳本管理器,讓我安裝!)

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

(我已經安裝了使用者樣式管理器,讓我安裝!)

// ==UserScript==
// @name         切换标签页自动暂停视频
// @namespace    http://tampermonkey.net/
// @version      1.0
// @description  当从含有视频的标签页切换到其他标签页时,视频自动暂停播放。

// @author       coldboy775
// @match        *://*/*
// @grant        none
// ==/UserScript==



(function() {
    'use strict';

    document.addEventListener('visibilitychange', function() {
        if (document.hidden) {
            // 当标签页不可见时
            const videos = document.getElementsByTagName('video');
            for (let video of videos) {
                if (!video.paused) {
                    video.pause(); // 暂停视频
                    video.setAttribute('data-was-playing', 'true');
                }
            }
        } else {
            // 当标签页再次可见时
            const videos = document.getElementsByTagName('video');
            for (let video of videos) {
                if (video.getAttribute('data-was-playing') === 'true') {
                    video.play(); // 恢复播放
                    video.removeAttribute('data-was-playing');
                }
            }
        }
    });
})();