Как запретить YouTube показывать уже просмотренные видео?


12

Есть ли способ запретить YouTube показывать видео, которые уже были просмотрены в списке рекомендуемых видео?


1
Быстрый взгляд на HTML заставляет меня думать, что это не должно быть слишком сложно сделать. Вы в основном хотите установить display: noneдля любого <ytd-compact-video-renderer>элемента, который содержит дочерний элемент #progress. Вы не сможете сделать это в CSS, но скрипт Tampermonkey должен быть достаточно простым. Я пойду попозже и напишу ответ ...
Аарон Ф

Ответы:


12

В настоящее время нет никакого лечения / обходного пути для этого. Помимо ручной блокировки их одно за другим, нет масштабируемых решений.

0

Но есть расширения, которые могут сделать так:


// ==UserScript==
// @version        1.1.1
// @name           Hide watched videos on YouTube
// @namespace      https://gist.github.com/xPaw/6324624
// @match          https://www.youtube.com/*
// @updateURL      https://gist.github.com/xPaw/6324624/raw/YoutubeHideWatched.user.js
// @downloadURL    https://gist.github.com/xPaw/6324624/raw/YoutubeHideWatched.user.js
// @grant          none
// ==/UserScript==

const app = document.querySelector( 'ytd-app' );

function HideVideos( a )
{
    app.querySelectorAll( 'ytd-thumbnail-overlay-resume-playback-renderer:not([data-hidden="true"])' ).forEach( element =>
    {
        element.dataset.hidden = true;

        while( ( element = element.parentNode ).tagName.toLowerCase() !== 'ytd-item-section-renderer' )
        {
            // Find the container element for this video
        }

        element.hidden = true;
    } );
}

function ProcessPage()
{
    if( !window.location.pathname.startsWith( '/feed/subscriptions' ) )
    {
        return;
    }

    const list = app.querySelector( 'ytd-section-list-renderer' );

    if( list.dataset.hooked )
    {
        return;
    }

    list.dataset.hooked = true;
    list.addEventListener( 'yt-next-continuation-data-updated', HideVideos );

    // TODO: Find an event to fix this
    new MutationObserver( HideVideos ).observe( list, { childList: true, subtree: true } );
}

app.addEventListener( 'yt-navigate-finish', ProcessPage );

ProcessPage();

3
Это позор. Я получаю одинаковые дюжины музыкальных клипов все время, но полностью блокировать их - это излишне.
JollyJoker

1
о, хорошо, вы обновили пользовательский скрипт! :-)
Аарон Ф

Некоторые не работают, но это то, что я искал. Tks
DGaleano

Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.