过滤低互动(自定义点赞、评论数阈值)微博,并移除顶部导航栏、悬浮刷新按钮和诸多横线等界面元素。
As of
// ==UserScript==
// @name 【微博移动端】内容过滤与界面简化
// @namespace https://github.com/realSilasYang
// @version 2025-9-13
// @description 过滤低互动(自定义点赞、评论数阈值)微博,并移除顶部导航栏、悬浮刷新按钮和诸多横线等界面元素。
// @author 阳熙来
// @icon 
// @license GNU GPLv3
// @match *://m.weibo.cn/*
// @match *://huati.weibo.cn/*
// @match *://h5.video.weibo.com/*
// @match *://card.weibo.com/*
// @match *://weibo.com/l/wblive/m/show/*
// ==/UserScript==
(function () {
'use strict';
// -------------------- 配置区域 --------------------
// 评论数低于此值的微博会被移除
const MIN_COMMENTS = 5;
// 点赞数低于此值的微博会被移除
const MIN_LIKES = 10;
// 微博帖子选择器(支持两种布局)
const POST_SELECTOR = '.wb-item-wrap, .card.weibo-member';
// 页面上需要直接移除的 UI 元素选择器
const SELECTORS_TO_REMOVE = [
'.lite-topbar.main-top', // 顶部导航栏
'.refresh-btn.lite-iconf' // 悬浮刷新按钮
];
// 统一管理所有需要去掉横线的 CSS 规则
// 以后新增规则只需在此数组中添加一条
const BORDER_FIX_RULES = [
/* 去掉 .lite-line 元素的上边框 */
`.lite-line { border-top-width: 0px !important; }`,
/* 去掉顶部导航栏 .lite-topbar.lite-page-top 的底部横线和阴影 */
`.lite-topbar.lite-page-top { border-bottom: none !important; box-shadow: none !important; }`,
/* 去掉评论输入栏 .lite-page-editor 的顶部横线和阴影 */
`.lite-page-editor { border-top: none !important; box-shadow: none !important; }`,
/* 去掉微博卡片内部的横线(头像栏、正文模块、卡片容器) */
`.weibo-top,
.weibo-og,
.wb-item-wrap .card-wrap {
border-top: none !important;
border-bottom: none !important;
box-shadow: none !important;
}`
];
/**
* 注入统一的横线去除样式
* 只会执行一次,避免重复插入 <style>
*/
function applyBorderFixes() {
if (!document.getElementById('unified-border-fix-style')) {
const style = document.createElement('style');
style.id = 'unified-border-fix-style';
// 将数组中的所有规则拼接成一个字符串
style.textContent = BORDER_FIX_RULES.join('\n');
document.head.appendChild(style);
}
}
/**
* 解析互动数(评论/点赞)
* @param {Element} iconElement - 评论或点赞图标元素
* @returns {number} - 返回解析后的数值
*/
function parseCount(iconElement) {
if (!iconElement) return 0;
const h4 = iconElement.parentElement.querySelector('h4');
if (!h4 || !h4.textContent) return 0;
const text = h4.textContent.trim();
// 处理“万”单位
if (text.includes('万')) return parseFloat(text) * 10000;
const num = parseInt(text, 10);
return isNaN(num) ? 0 : num;
}
/**
* 判断微博帖子是否应保留
* @param {Element} box - 微博帖子根元素
* @returns {boolean} - true 表示保留,false 表示移除
*/
function shouldKeep(box) {
let commentIcon, likeIcon;
if (box.matches('.wb-item-wrap')) {
// 普通布局
commentIcon = box.querySelector('.lite-iconf-comments');
likeIcon = box.querySelector('.lite-iconf-like');
} else if (box.matches('.card.weibo-member')) {
// 会员布局
commentIcon = box.querySelector('.m-font-comment');
likeIcon = box.querySelector('.m-icon-like');
} else {
return true; // 不匹配的元素直接保留
}
const commentNum = parseCount(commentIcon);
const likeNum = parseCount(likeIcon);
return commentNum >= MIN_COMMENTS && likeNum >= MIN_LIKES;
}
/**
* 过滤单个微博帖子
* @param {Element} box - 微博帖子根元素
*/
function filterSingle(box) {
if (!shouldKeep(box)) {
box.remove();
}
}
/**
* 批量过滤微博帖子
* @param {Element|Document} root - 搜索的根节点
*/
function filterAll(root = document) {
root.querySelectorAll(POST_SELECTOR).forEach(filterSingle);
}
/**
* 移除指定的 UI 元素
*/
function cleanupUI() {
SELECTORS_TO_REMOVE.forEach(selector => {
document.querySelectorAll(selector).forEach(element => element.remove());
});
}
// -------------------- 主逻辑 --------------------
// 监听 DOM 变化(微博是动态加载的)
const observer = new MutationObserver(() => {
applyBorderFixes(); // 应用横线去除样式
cleanupUI(); // 移除 UI 元素
filterAll(); // 过滤低互动微博
});
observer.observe(document.documentElement, {
childList: true, // 监听子节点变化
subtree: true // 监听整个子树
});
/**
* 初始运行(页面加载完成时执行一次)
*/
function initialRun() {
applyBorderFixes();
cleanupUI();
filterAll();
}
// 根据页面加载状态决定何时执行初始运行
if (document.readyState === 'loading') {
document.addEventListener('DOMContentLoaded', initialRun);
} else {
initialRun();
}
})();