您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Greasy Fork is available in English.
This script is based on YouTube Web Tweaks (except with only the removal of video paused continue watching popup and it keeps the shorts player)
当前为
// ==UserScript== // @name YouTube Web Tweaks Lite // @version 1.3.0 // @description This script is based on YouTube Web Tweaks (except with only the removal of video paused continue watching popup and it keeps the shorts player) // @author Magma_Craft // @license MIT // @match *://www.youtube.com/* // @namespace http://greasyfork.icu/en/users/933798 // @icon https://www.youtube.com/favicon.ico // @unwrap // @run-at document-start // @unwrap // @inject-into page // @allFrames true // @grant none // ==/UserScript== // Modifiying yt.config flags (function() { window['yt'] = window['yt'] || {}; yt['config_'] = yt.config_ || {}; yt.config_['EXPERIMENT_FLAGS'] = yt.config_.EXPERIMENT_FLAGS || {}; var iv = setInterval(function() { yt.config_.IS_TABLET = true; yt.config_.DISABLE_YT_IMG_DELAY_LOADING = true; yt.config_.EXPERIMENT_FLAGS.polymer_verifiy_app_state = false; yt.config_.EXPERIMENT_FLAGS.desktop_delay_player_resizing = false; yt.config_.EXPERIMENT_FLAGS.web_animated_like = false; yt.config_.EXPERIMENT_FLAGS.web_animated_like_lazy_load = false; yt.config_.EXPERIMENT_FLAGS.render_unicode_emojis_as_small_images = true; yt.config_.EXPERIMENT_FLAGS.kevlar_refresh_on_theme_change = false; yt.config_.EXPERIMENT_FLAGS.kevlar_watch_cinematics = false; }, 1); var to = setTimeout(function() { clearInterval(iv); }, 1000) })(); // Improving the system performance by using their native engine ((__CONTEXT01__) => { const win = this instanceof Window ? this : window; // Create a unique key for the script and check if it is already running const hkey_script = 'ikkaorpwuzvt'; if (win[hkey_script]) throw new Error('Duplicated Userscript Calling'); // avoid duplicated scripting win[hkey_script] = true; /** @type {globalThis.PromiseConstructor} */ const Promise = ((async () => { })()).constructor; const cleanContext = async (win) => { const waitFn = requestAnimationFrame; // shall have been binded to window try { let mx = 16; // MAX TRIAL const frameId = 'vanillajs-iframe-v1' let frame = document.getElementById(frameId); let removeIframeFn = null; if (!frame) { frame = document.createElement('iframe'); frame.id = 'vanillajs-iframe-v1'; frame.sandbox = 'allow-same-origin'; // script cannot be run inside iframe but API can be obtained from iframe let n = document.createElement('noscript'); // wrap into NOSCRPIT to avoid reflow (layouting) n.appendChild(frame); while (!document.documentElement && mx-- > 0) await new Promise(waitFn); // requestAnimationFrame here could get modified by YouTube engine const root = document.documentElement; root.appendChild(n); // throw error if root is null due to exceeding MAX TRIAL removeIframeFn = (setTimeout) => { const removeIframeOnDocumentReady = (e) => { e && win.removeEventListener("DOMContentLoaded", removeIframeOnDocumentReady, false); win = null; setTimeout(() => { n.remove(); n = null; }, 200); } if (document.readyState !== 'loading') { removeIframeOnDocumentReady(); } else { win.addEventListener("DOMContentLoaded", removeIframeOnDocumentReady, false); } } } while (!frame.contentWindow && mx-- > 0) await new Promise(waitFn); const fc = frame.contentWindow; if (!fc) throw "window is not found."; // throw error if root is null due to exceeding MAX TRIAL const { requestAnimationFrame, cancelAnimationFrame, getComputedStyle, setInterval, clearInterval, setTimeout, clearTimeout } = fc; const res = { requestAnimationFrame, cancelAnimationFrame, getComputedStyle, setInterval, clearInterval, setTimeout, clearTimeout }; for (let k in res) res[k] = res[k].bind(win); // necessary res.animate = fc.Element.prototype.animate; if (removeIframeFn) Promise.resolve(res.setTimeout).then(removeIframeFn); return res; } catch (e) { console.warn(e); return null; } }; cleanContext(win).then(__CONTEXT02__ => { const { requestAnimationFrame, cancelAnimationFrame, getComputedStyle, setInterval, clearInterval, setTimeout, clearTimeout } = __CONTEXT02__; const { animate } = __CONTEXT02__; const { frames, defineProperty, window, CDATASection, ProcessingInstruction, FocusEvent } = __CONTEXT01__; const ENABLE_NATIVE_CONSTRUCTOR_CHECK = false; let cids = {}; function cleanCId(k) { Promise.resolve().then(() => clearInterval(cids[k])); } Object.defineProperty = function (o, p, opts) { if (arguments.length !== 3) return defineProperty.apply(this, arguments); if (o instanceof Window) { if (p === 'getComputedStyle') return; if (p === 'Promise' && (p in o)) return; // WaterFox Classic if (p === 'customElements' || p === 'Polymer') { if (p in o) return; // duplicate declaration? } const value = opts.value; if (value) { opts.writable = true; opts.configurable = true; opts.enumerable = true; } if (p === 'ytInitialPlayerResponse' || p === 'playerResponse') { // Firefox Chatroom? TBC } else { console.log(923, 'window[p]=', p, opts); } return defineProperty.call(this, o, p, opts); } const nativeConstructorCheck = ENABLE_NATIVE_CONSTRUCTOR_CHECK ? (o.constructor + "").indexOf('native code') > 0 : true; if (p.startsWith('__shady_')) { const { get, value } = opts; if (!get) { o[p] = value; return; } if (p === '__shady_native_eventPhase') { // Event -> __shady_native_eventPhase return defineProperty.call(this, o, p, opts); } let constructor = o instanceof Node ? Node : o instanceof DocumentFragment ? DocumentFragment : o instanceof Document ? Document : null; if (!constructor) { let constructorName = (o.constructor || 0).name; if (constructorName === 'Node') { constructor = Node; } } if (constructor && opts && (typeof opts.get === 'function')) { if (!(p in o.constructor.prototype) && !(p in o)) { defineProperty.call(this, o.constructor.prototype, p, opts); } return; } console.log(926, o, p, opts, !!constructor, !!opts, !!(typeof opts.get === 'function')) // return; } if ((p in o) && nativeConstructorCheck) { if (o instanceof Text) return; if (o instanceof Comment) return; if (CDATASection && o instanceof CDATASection) return; if (ProcessingInstruction && o instanceof ProcessingInstruction) return; if (o instanceof Event) return; if (FocusEvent && o instanceof FocusEvent) return; } return defineProperty.call(this, o, p, opts); } const asserter = (f) => Promise.resolve().then(() => console.assert(f(), f + "")); const setVJS = () => { if (window.Promise !== Promise) window.Promise = Promise; if (window.getComputedStyle !== getComputedStyle) window.getComputedStyle = getComputedStyle; if (Element.prototype.animate !== animate) Element.prototype.animate = animate; if (window.requestAnimationFrame !== requestAnimationFrame) window.requestAnimationFrame = requestAnimationFrame if (window.cancelAnimationFrame !== cancelAnimationFrame) window.cancelAnimationFrame = cancelAnimationFrame }; const finishFn = () => { cids.finish = 0; setVJS(); try { document.getElementById('zihrS').remove(); } catch (e) { } cleanCId('timeVJS'); if (document.isConnected === false) return; setTimeout(() => { if (document.isConnected === false) return; asserter(() => window.Promise === Promise); asserter(() => window.getComputedStyle === getComputedStyle); asserter(() => Element.prototype.animate === animate); asserter(() => window.requestAnimationFrame === requestAnimationFrame); asserter(() => window.cancelAnimationFrame === cancelAnimationFrame); }, 800); }; function fastenFinishFn() { if (cids.finish > 0) { clearInterval(cids.finish); cids.finish = setTimeout(finishFn, 40); } } function preFinishFn() { let mo = new MutationObserver(function () { Promise.resolve().then(fastenFinishFn) mo.disconnect(); mo.takeRecords(); mo = null; }); mo.observe(document, { subtree: true, childList: true }); return setTimeout(finishFn, 400); } cids.timeVJS = setInterval(() => { if (!cids.finish && ('Polymer' in window)) cids.finish = preFinishFn(); setVJS(); }, 1); let isInnerFrame = false; try { isInnerFrame = window !== top && window.document.domain === top.document.domain; } catch (e) { } if (!isInnerFrame) { console.groupCollapsed( "%cYouTube Native - Vanilla Engine (Experimental)", "background-color: #e0005a ; color: #ffffff ; font-weight: bold ; padding: 4px ;" ); console.log("Script is loaded."); console.log("This is an experimental script."); console.log("If you found any issue in using YouTube, please disable this script to check whether the issue is due to this script or not."); console.groupEnd(); } }); })({ frames, defineProperty: Object.defineProperty, window, CDATASection, ProcessingInstruction, FocusEvent }); // CSS tweaks to be applied (including removal of "Video paused. Continue watching?" popup) (function() { ApplyCSS(); function ApplyCSS() { var styles = document.createElement("style"); styles.innerHTML=` /* Hide Shorts on related videos (including remixes) */ ytd-reel-shelf-renderer.style-scope.ytd-item-section-renderer { display: none !important; } ytd-reel-shelf-renderer.ytd-structured-description-content-renderer { display: none !important; } /* Remove ambient light on watch page */ cinematics.ytd-watch-flexy { display: none !important; }` document.head.appendChild(styles); } })(); Object.defineProperties(document, { 'hidden': {value: false}, 'webkitHidden': {value: false}, 'visibilityState': {value: 'visible'}, 'webkitVisibilityState': {value: 'visible'} }); setInterval(function(){ document.dispatchEvent( new KeyboardEvent( 'keyup', { bubbles: true, cancelable: true, keyCode: 143, which: 143 } ) ); }, 60000);