更好的 Bilibili
// ==UserScript==
// @name Better Bilibili
// @namespace jerryshell
// @version 0.2
// @description 更好的 Bilibili
// @author github.com/jerryshell
// @match *://*.bilibili.com/*
// @icon https://www.google.com/s2/favicons?sz=64&domain=bilibili.com
// @grant none
// @license GNU Affero General Public License v3.0
// ==/UserScript==
/* jshint esversion: 6 */
(() => {
'use strict';
new MutationObserver(() => {
// 删除视频评论区
const videoCommentElement = document.querySelector('div.bili-comment');
if (videoCommentElement) {
videoCommentElement.remove();
}
// 删除视频弹幕列表
const danmakuBoxElement = document.querySelector('div#danmukuBox');
if (danmakuBoxElement) {
danmakuBoxElement.childNodes.forEach(node => node.remove());
}
// 删除视频弹幕
const videoDanmakuElement = document.querySelector('div.b-danmaku');
if (videoDanmakuElement) {
videoDanmakuElement.remove();
}
// 删除视频弹幕发送
const videoDanmakuSendElement = document.querySelector('div.bpx-player-sending-area');
if (videoDanmakuSendElement) {
videoDanmakuSendElement.remove();
}
// 删除首页分区导航
const biliChannel = document.querySelector('div.bili-header__channel');
if (biliChannel) {
biliChannel.childNodes.forEach(node => node.remove());
}
// 删除首页左导航栏
const leftEntryElement = document.querySelector('ul.left-entry');
if (leftEntryElement) {
leftEntryElement.childNodes.forEach(node => node.remove());
}
// 删除首页搜索栏的占位文字
const navSearchInputElement = document.querySelector('input.nav-search-input');
if (navSearchInputElement) {
navSearchInputElement.removeAttribute('placeholder');
navSearchInputElement.removeAttribute('title');
}
// 首页只保留【科技】和【纪录片】分区
const biliGridList = document.querySelectorAll('section.bili-grid');
if (biliGridList) {
biliGridList.forEach(biliGrid => {
const titleElement = biliGrid.querySelector('a.title');
if (titleElement) {
const title = titleElement.textContent;
if (title.indexOf('科技') === -1 && title.indexOf('纪录片') === -1) {
biliGrid.remove();
}
} else {
biliGrid.remove();
}
});
}
// 删除动态评论区
const biliDynActionCommentElement = document.querySelector('div.bili-dyn-action.comment');
if (biliDynActionCommentElement) {
biliDynActionCommentElement.remove();
}
const biliDynItemInteractionElement = document.querySelector('div.bili-dyn-item__interaction');
if (biliDynItemInteractionElement) {
biliDynItemInteractionElement.remove();
}
// 删除动态左导航栏
const navLinkItemElementList = document.querySelectorAll('li.nav-link-item');
if (navLinkItemElementList) {
navLinkItemElementList.forEach(node => {
node.remove();
});
}
// 删除动态话题
const topicPanelElement = document.querySelector('div.topic-panel');
if (topicPanelElement) {
topicPanelElement.remove();
}
// 删除动态搜索栏的占位文字
const navSearchKeywordElement = document.querySelector('input.nav-search-keyword')
if (navSearchKeywordElement) {
navSearchKeywordElement.removeAttribute('placeholder');
navSearchKeywordElement.removeAttribute('title');
}
// 删除搜索栏的热搜面板
const trendingElement = document.querySelector('div.trending');
if (trendingElement) {
trendingElement.remove();
}
}).observe(document.querySelector('body'), {
childList: true,
attributes: true,
subtree: true,
});
})();