半自动屏蔽网页内容,例如悬浮窗

根据F12查找到的element(div)的name或者id,对其进行自动屏蔽的通用脚本,***请注意第15~17行***,自行修改需要屏蔽的网站和内容(现在的blockeName和blockedPageUrls是用来屏蔽嘶哩嘶哩的悬浮窗广告的)

目前为 2023-08-28 提交的版本。查看 最新版本

// ==UserScript==
// @name         半自动屏蔽网页内容,例如悬浮窗
// @namespace    http://tampermonkey.net/
// @version      1.25
// @description  根据F12查找到的element(div)的name或者id,对其进行自动屏蔽的通用脚本,***请注意第15~17行***,自行修改需要屏蔽的网站和内容(现在的blockeName和blockedPageUrls是用来屏蔽嘶哩嘶哩的悬浮窗广告的)
// @author       shepherdZheng
// @match        http://*/*
// @match        https://*/*
// @grant        none
// @license      MIT
// ==/UserScript==

(function() {
    'use strict';
    //在下面两行中输入需要屏蔽的name或者id,以及网页列表,数量/长度不限。
    var blockeName = ['coupletright','coupletleft','HMRichBox','HMrichA'];
    var blockedPageUrls = ['https://www.silisilifun.com/', 'https://www.silisili.tv'];

    //确认是否是需要河蟹的网页
    function isBlockedPageUrl() {
        for (var a = 0; a < blockedPageUrls.length; a++) {
            if (window.location.href.indexOf(blockedPageUrls[a]) !== -1) {
                return true;
            }
        }
        return false;
    }
    //查找网页内容,进行河蟹
    function getElementandRemove(i,blockeName) {
        if (i < 10) { //网速比较慢的情况下,请调高i<的值,例如,网页需要10秒加载完的话,这里应该大于10*2,大于20。
            setTimeout(function() {
                //console.log(i); //调试用
                //console.log('AAAAAAAAAAAAAAAAAAAAAAAAAAA');//调试用,和k与j的输出相区分
                var elements = document.getElementsByTagName('*');
                //var divzElements = document.querySelectorAll('[style*="bottom:0px"][style*="right:0px"]');//这个方法对于一般的div是有效的,但没办法选中那个奇妙的divz。。。?采用下面那行的特征可以选中
                var divzElements = document.querySelectorAll('[style*="display: block;"]');//silisili改变了右下角悬浮窗的写法,现在它会随机生成自身的id,有趣有趣。
                for(var b=0; b<divzElements.length; b++) {
                    console.log(divzElements[b]);
                    divzElements[b].style.display = 'none';
                }
                for(var k=0; k<elements.length; k++) {
                    //console.log(k); //调试用
                    for (var j = 0; j < blockeName.length; j++) {
                        //console.log(j); //调试用
                        var name = blockeName[j];
                        if(elements[k].getAttribute('id') === name || elements[k].getAttribute('name') === name) {
                            elements[k].style.display = 'none';
                            //无法屏蔽掉网页内容时请依次取消下面三行的注释(手段逐渐过激)
                            //elements[k].style.display = "none !important";
                            //elements[k].style.visibility = "hidden !important";
                            //elements[k].parentNode.removeChild(element);

                            //if(k == elements.length){
                            //    i += 233;//试图写一个提前结束i循环的判断,但不知为何i循环是会自己提前结束的。。。???
                            //}
                        }
                    }
                }
                getElementandRemove(i + 1);
            }, 500);//非常精妙的异步方法,语法原理我还没看懂,反正框架是这样的。。。
        }
    }
    // 主函数,js要实现异步编程还挺麻烦的——只会python的初学者的感想。
    if (isBlockedPageUrl()) {
        getElementandRemove(0,blockeName);
    }
})();