您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
B站视频过滤器
// ==UserScript== // @name bilibili filter // @namespace http://tampermonkey.net/ // @version 0.1 // @description B站视频过滤器 // @author You // @match *://*.bilibili.com/* // @icon  // @grant none // @license MIT // ==/UserScript== (function() { 'use strict'; var box = ` <div id="warp" class="warp" style=" display: flex; justify-content: center; align-items: center; flex-direction: column; "> <div class="content"> <div id="gbt_title" class="gbt_title" style=" padding-top:20px; margin-bottom:0px; font-weight: 800; text-align: center"> B站过滤插件 </div> <div id="warp_form" style=" display: flex; justify-content: center; align-items: center; flex-direction: column; "> <div style="margin: 20px 0;"> <span>时长:</span> <input type="number" id="time1" style=" width: 20px; margin: 0 5px; border: none; border-bottom: 1px solid black; outline: none; text-align: center; "> <span>~</span> <input type="number" id="time2" style=" width: 20px; margin: 0 5px; border: none; border-bottom: 1px solid black; outline: none; text-align: center; "><span>分钟</span> <button id="warp_btn" style="margin-left:10px;">过滤</button> </div> </div> </div> </div> ` // Your code here... window.onload = function () { console.log("欢迎使用bilibili过滤功能") document.querySelector(".contribution-sidenav").insertAdjacentHTML('beforeend', box) document.getElementById("warp_btn").onclick = function () { console.log("filter") let minTime = document.getElementById("time1").value * 60 || 0 let maxTime = document.getElementById("time2").value * 60 || Number.POSITIVE_INFINITY let children = document.getElementsByClassName("cube-list")[0].children // console.log(children) for (let i = 0; i < children.length; i++) { const element = children[i]; let videoTime = NaN let timestr = (element.getElementsByTagName("span")[0].innerText).split(":") if (timestr.length === 3) { videoTime = Number(timestr[0] * 60 * 60) + Number(timestr[1] * 60) + Number(timestr[2]) } else { videoTime = Number(timestr[0] * 60) + Number(timestr[1]) } if (videoTime < minTime || videoTime > maxTime) { children[i].style['display'] = "none" } else { children[i].style['display'] = "" } } console.log(children) return false; } } })();