【微博移动端】内容过滤与界面简化

过滤低互动(自定义点赞、评论数阈值)微博,并移除顶部导航栏、悬浮刷新按钮和诸多横线等界面元素。

As of 13.09.2025. See ბოლო ვერსია.

You will need to install an extension such as Tampermonkey, Greasemonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey or Userscripts to install this script.

You will need to install an extension such as Tampermonkey to install this script.

You will need to install a user script manager extension to install this script.

(I already have a user script manager, let me install it!)

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

(I already have a user style manager, let me install it!)

// ==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();
    }
})();