您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Automatically toggle dark/light theme
// ==UserScript== // @name Youtube Automatic Theme // @namespace http://tampermonkey.net/ // @version 0.1 // @description Automatically toggle dark/light theme // @author [email protected] // @run-at document-idle // @match https://www.youtube.com/** // @grant none // ==/UserScript== (function () { "use strict"; const getAvatarButton = () => { return new Promise((resolve) => { const button = document.getElementById("avatar-btn"); resolve(button); }); }; const getMenuButton = () => { return new Promise((resolve) => { const menu = document.getElementsByClassName( "style-scope yt-multi-page-menu-section-renderer" )[14]; resolve(menu); }); }; const renderButton = async () => { return new Promise(async (resolve) => { let avatar; let menu; avatar = await getAvatarButton(); avatar.click(); setTimeout(async () => { menu = await getMenuButton(); menu.click(); avatar.click(); resolve("done"); }, 2000); }); }; const toggleTheme = () => { if (window.matchMedia) { var isDarkMode = document .querySelector("paper-toggle-button") .hasAttribute("checked"); if (window.matchMedia("(prefers-color-scheme: light)").matches) { if (isDarkMode) document.getElementById("toggleButton").click(); } if (window.matchMedia("(prefers-color-scheme: dark)").matches) { if (!isDarkMode) document.getElementById("toggleButton").click(); } } }; const start = () => { renderButton().then((res) => { toggleTheme(); }); }; start(); })();