您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
动态页切换up并选择视频添加到稍后再看
// ==UserScript== // @name b站 动态页添加稍后再看 // @namespace http://tampermonkey.net/ // @version 0.3 // @description 动态页切换up并选择视频添加到稍后再看 // @author WindOfCast // @match *://t.bilibili.com/* // @icon  // @grant GM_notification // @homepage https://gitee.com/windofcast/ // @website https://space.bilibili.com/367207503 // @license AGPL License // ==/UserScript== (function () { 'use strict'; const common = (function () { class Common { #currentIconIndex; #currentVideoIndex; #previousVideoIndex; #upIconList; #dynList; #dynVideoList; #border = "1px solid #033eff"; #upIconListPrevBtn; #upIconListNextBtn; #mainWidth; #upIconWidth; #pageIndex; constructor() { this.#currentIconIndex = -1; this.#currentVideoIndex = -1; this.#previousVideoIndex = -1; this.#upIconList = undefined; this.#dynList = []; this.#dynVideoList = []; this.#pageIndex = 0; } notification(messageObj) { GM_notification({ title: messageObj.title, text: messageObj.message, timeout: messageObj.timeout || 3000, }); } backTop() { let backTop = document.querySelector('.back-top'); if (backTop) { backTop.click(); } } pageJump(direction) { let index = direction ? this.#currentIconIndex + 1 : this.#currentIconIndex; if (index === 0) { return; } let volume = index * this.#upIconWidth; let nextPage = volume / this.#mainWidth; console.info(volume, nextPage, this.#pageIndex) if (this.#pageIndex === Math.floor(nextPage)) { return; } if (nextPage > this.#pageIndex && Math.ceil(nextPage) > this.#pageIndex) { this.#upIconListNextBtn.click(); this.#pageIndex++; } else if (nextPage < this.#pageIndex && Math.floor(nextPage) < this.#pageIndex) { this.#upIconListPrevBtn.click(); this.#pageIndex--; } } getItemWidthByAttributes(element, ...attributes) { let style = window.getComputedStyle(element); return attributes.reduce((acc, attr) => acc + parseInt(style[attr]), 0); } moveUpIcon(code) { let direction = false; if (code === "ArrowRight") { direction = true; } else if (code !== "ArrowLeft") { return; } if (direction && this.#currentIconIndex < this.#upIconList.length - 1) { this.#upIconList[++this.#currentIconIndex].click() } else if (!direction && this.#currentIconIndex > 0) { this.#upIconList[--this.#currentIconIndex].click() } this.pageJump(direction) this.backTop(); } moveUpVideo(code) { let direction = false; if (code === "ArrowDown") { direction = true; } else if (code !== "ArrowUp") { return; } if (this.#dynVideoList.length === 0) { this.notification({ title: '提示', message: 'UP最近没有更新视频' }) return; } if (this.#currentVideoIndex === -1 && this.#previousVideoIndex === -1) { this.#currentVideoIndex = 0; this.border(this.#currentVideoIndex, this.#previousVideoIndex); return; } this.#previousVideoIndex = this.#currentVideoIndex; let loadMoreVideo = false; if (direction && this.#currentVideoIndex + 1 > this.#dynVideoList.length - 1) { this.loadVideoList(false, 100); loadMoreVideo = true; } setTimeout(() => { if (direction && this.#currentVideoIndex < this.#dynVideoList.length - 1) { this.#currentVideoIndex++; this.border(this.#currentVideoIndex, this.#previousVideoIndex); } else if (!direction && this.#currentVideoIndex > 0) { this.#currentVideoIndex--; this.border(this.#currentVideoIndex, this.#previousVideoIndex); } else if (!direction && this.#currentVideoIndex === 0) { this.backTop(); this.#currentVideoIndex--; this.border(this.#currentVideoIndex, this.#previousVideoIndex); } }, loadMoreVideo ? 200 : 0); } addMark() { if (this.#currentVideoIndex === -1) { return; } let dynVideoItem = this.#dynList[this.#dynVideoList[this.#currentVideoIndex]]; let markItem = dynVideoItem.querySelector('.bili-dyn-card-video__mark'); let messageObj = { title: '提示', message: undefined }; let title = dynVideoItem.querySelector('.bili-dyn-card-video__title').textContent; if (this.hasClass(markItem, 'active')) { messageObj.message = `添加稍后再看 [${title}]`; } else { messageObj.message = `移除稍后再看 [${title}]`; } this.notification(messageObj) markItem.click(); } border(draw, clear) { if (draw !== -1) { let dynVideoItem = this.#dynList[this.#dynVideoList[draw]]; dynVideoItem.style.border = this.#border; dynVideoItem.scrollIntoView({behavior: 'auto', block: 'center'}); } if (clear !== -1) { this.#dynList[this.#dynVideoList[clear]].style.border = ''; } } run() { this.keydownListener(); this.loadDynList(); this.loadVideoList(); this.backTop(); } keydownListener() { document.addEventListener("keydown", (evt) => { let code = evt.code; switch (code) { case "ArrowRight": case "ArrowLeft": this.moveUpIcon(code); break; case "ArrowUp": case "ArrowDown": this.moveUpVideo(code); break; case "Enter": this.addMark(); break; } }) } loadDynList() { this.#upIconList = document.querySelectorAll(".bili-dyn-up-list__item"); this.#upIconList.forEach((item, index) => { item.addEventListener('click', () => { this.#currentIconIndex = index; this.loadVideoList(true); }) }) this.#currentIconIndex = 0; this.#upIconListPrevBtn = document.querySelector('.prev').querySelector('.bili-dyn-up-list__nav__btn'); this.#upIconListNextBtn = document.querySelector('.next').querySelector('.bili-dyn-up-list__nav__btn'); this.#mainWidth = this.getItemWidthByAttributes(document.querySelector('.bili-dyn-up-list__content'), "width"); let noUp; let baseIcon = (noUp = this.#upIconList.length > 1) ? this.#upIconList[1] : this.#upIconList[0]; this.#upIconWidth = this.getItemWidthByAttributes(baseIcon, "width", "marginLeft", "marginRight"); if (!noUp) { this.#upIconWidth += 3; } } loadVideoList(reload = false, timeout = 500) { if (reload) { this.#previousVideoIndex = -1; this.#currentVideoIndex = -1; } setTimeout(() => { this.#dynVideoList = []; this.#dynList = document.querySelectorAll(".bili-dyn-list__item"); for (let i = 0; i < this.#dynList.length; i++) { let dynItem = this.#dynList[i]; if (dynItem.querySelector('a') && this.hasClass(dynItem.querySelector('.bili-dyn-content__orig'), 'reference')) { this.#dynVideoList.push(i); } } if (this.#dynVideoList.length > 0 && this.#dynVideoList[0] === 0) { this.#currentVideoIndex = 0 this.border(this.#currentVideoIndex, this.#previousVideoIndex) } }, timeout); } hasClass(element, cls) { let className = element.className; return className.indexOf(cls) === -1; } } let common = null; return (function () { if (!common) { common = new Common(); } return common; })(); })(); window.addEventListener("load", () => { setTimeout(() => { console.log("[b站 动态页添加稍后再看]: 已加载!"); common.run(); }, 1000); }) })();