Youtube No Flexy Mode

Disable Flexy Mode

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Greasemonkey 油猴子Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Violentmonkey 暴力猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴Userscripts ,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey 篡改猴,才能安装此脚本。

您需要先安装一款用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name         Youtube No Flexy Mode
// @namespace    http://tampermonkey.net/
// @version      0.50
// @description  Disable Flexy Mode
// @author       Botan
// @match        *://*.youtube.com/*
// @grant        none
// @run-at       document-end
// ==/UserScript==


// Thanks to AlexT. this fix does not longer use any intervals, it instead uses the Youtube API directly.
(function() {
    'use strict';
    if (window.top != window.self) return;
    console.log('Youtube No Flexy Mode');

    // Disables (if available) the creation of the new flexy dom.
    function disableFlexyFeature() {
        let cfg = (typeof window.ytcfg === "undefined") ? false : window.ytcfg.get("EXPERIMENT_FLAGS");
        if (!cfg || cfg.kevlar_flexy_watch_new_dom === false) return;

        cfg.kevlar_flexy_watch_new_dom = false;
        console.log('Set kevlar_flexy_watch_new_dom to false');

        cfg.kevlar_transparent_player_background = false;
        console.log('Set kevlar_transparent_player_background to false');

        window.ytcfg.set("EXPERIMENT_FLAGS", cfg);
    }

    disableFlexyFeature();
    document.addEventListener("yt-navigate-start", disableFlexyFeature, true);
})();