屏蔽百度搜索网页中无用信息

屏蔽百度搜索网页的引导元素,并去除百度首页搜索框自动加载的热搜内容词条,清空 placeholder

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 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    http://tampermonkey.net/
// @version      1.6
// @description  屏蔽百度搜索网页的引导元素,并去除百度首页搜索框自动加载的热搜内容词条,清空 placeholder
// @author       sept
// @match        https://www.baidu.com/*
// @grant        none
// @license      MIT
// @icon         
// ==/UserScript==

(function () {
    'use strict';

    // 在 DOM 加载前就应用样式
    var style = document.createElement('style');
    style.textContent = '#s_new_search_guide { display: none !important; }';
    document.head.appendChild(style);

    // 使用 MutationObserver 确保元素被立即隐藏
    var guideObserver = new MutationObserver(function (mutations) {
        mutations.forEach(function (mutation) {
            if (mutation.type === 'childList') {
                var guideElement = document.getElementById('s_new_search_guide');
                if (guideElement) {
                    guideElement.style.display = 'none';
                    guideObserver.disconnect(); // 找到元素后停止观察
                }
            }
        });
    });

    // 开始观察整个文档
    guideObserver.observe(document.body, {
        childList: true,
        subtree: true
    });

    // 获取百度搜索框元素
    var inputElement = document.getElementById('kw'); // 百度搜索框的 ID 是 'kw'

    if (inputElement) {
        // 提前清空 placeholder
        inputElement.placeholder = '';

        // 使用 MutationObserver 监控 placeholder 的变化
        // 监控chat-input-area内的textarea
        var chatAreaObserver = new MutationObserver(function (mutations) {
            mutations.forEach(function (mutation) {
                // 查找chat-input-area内的所有textarea
                var chatArea = document.getElementById('chat-input-area');
                if (chatArea) {
                    var textareas = chatArea.querySelectorAll('textarea');
                    textareas.forEach(function (textarea) {
                        // 清空所有placeholder属性
                        textarea.placeholder = '';
                        textarea.removeAttribute('data-ai-placeholder');
                        textarea.removeAttribute('data-normal-placeholder');
                    });
                }
            });
        });

        // 开始监控body的子节点变化
        chatAreaObserver.observe(document.body, {
            childList: true,
            subtree: true
        });

        var placeholderObserver = new MutationObserver(function (mutations) {
            mutations.forEach(function (mutation) {
                if (mutation.type === 'attributes' && mutation.attributeName === 'placeholder') {
                    // 如果 placeholder 被动态加载,立即清空
                    inputElement.placeholder = '';
                    placeholderObserver.disconnect(); // 停止监控,避免重复清空
                }
            });
        });

        // 配置 MutationObserver,监控 placeholder 属性的变化
        var config = {
            attributes: true, // 监控属性变化
            attributeFilter: ['placeholder'] // 只监控 placeholder 属性
        };

        // 开始监控
        placeholderObserver.observe(inputElement, config);
    }
})();