隐藏热搜,删除广告和垃圾元素
// ==UserScript== // @name 百度首页编辑 // @namespace http://tampermonkey.net/ // @version 1.1 // @description 隐藏热搜,删除广告和垃圾元素 // @author 捈荼 // @license Apache License 2.0 // @match https://www.baidu.com // @run-at document-idie // @grant GM_getValue // @grant GM_setValue // ==/UserScript== // Commented by ChatGPT. // Declare an array containing the elements to be toggled var hotSearchElemrnt = [ document.getElementsByClassName("c-font-normal c-color-gray2 hot-refresh")[0], document.getElementsByClassName("s-news-rank-content")[0] ]; // Function to toggle the display style of the elements in the hotSearchElemrnt array function _changeState() { hotSearchElemrnt.forEach((e) => { e.style.display = e.style.display == 'none' ? '' : 'none'; }); } (function () { 'use strict'; // Check if the user has previously decided whether to remove trash elements if (GM_getValue('settingsDoRemoveTrushElements', -1) == -1) { // If not, prompt the user to confirm whether they want to remove trash elements const settingsRemoveTrushElements = confirm('是否需要删除广告等元素?'); // Store the user's decision in local storage GM_setValue('settingsDoRemoveTrushElements', settingsRemoveTrushElements); } // If the user has previously confirmed they want to remove trash elements, or if they just confirmed it if (GM_getValue('settingsDoRemoveTrushElements', -1) == true) { // Declare an object containing the class and id names of trash elements const trushElement = { class: ['s-news-list-wrapper c-container c-feed-box', 's-menu-item current', 'water-container', 's-loading s-opacity-border4-top'], id: ['s_menu_mine', 's-top-left', 'u1', 'bottom_layer', 's_side_wrapper'] }; // Remove all elements with the specified class names trushElement.class.forEach((ele) => { document.getElementsByClassName(ele)[0].remove(); }); // Remove all elements with the specified id names trushElement.id.forEach((id) => { document.getElementById(id).remove(); }); } // Check if the user has previously decided whether to hide hot search if (GM_getValue('settingsDoHideHotSearch', -1) == -1) { // If not, prompt the user to confirm whether they want to hide hot search const settingsRemoveTrushElements = confirm('是否需要隐藏热搜?'); // Store the user's decision in local storage GM_setValue('settingsDoHideHotSearch', settingsRemoveTrushElements); } // If the user has previously confirmed they want to hide hot search, or if they just confirmed it if (GM_getValue('settingsDoHideHotSearch', -1) == true) { // Toggle the display style of the hot search elements _changeState(); // Create a new image element const newIMG = document.createElement('img'); // Set the source of the image to a data URI newIMG.src = ''; // Set the alt attribute of the image newIMG.alt = 's-resize'; // Set the width and height of the image newIMG.width = '17'; newIMG.height = '10'; // Set the id of the image newIMG.id = 's-resize-usr-modified'; // Set the inline style of the image newIMG.style = 'margin: 0px 0px 0px 10px'; // Get the parent element of the image const parent = document.getElementsByClassName('c-font-medium c-color-t title-text')[0]; // Remove the child element (arrow icon) from the parent element parent.removeChild(document.getElementsByClassName('c-icon arrow')[0]); // Append the new image to the parent element document.getElementsByClassName('c-font-medium c-color-t title-text')[0].appendChild(newIMG); // Get the hot search toggle link element const keyLink = document.getElementsByClassName('s-opacity-border1-bottom')[0].firstElementChild; keyLink.setAttribute("href", "javascript:;"); keyLink.onclick = () => { // Toggle the display style of the hot search elements _changeState(); // Modify the image const img = document.getElementById('s-resize-usr-modified'); if (img.getAttribute('alt') == 's-resize-1') { img.setAttribute('src', ''); img.setAttribute('alt', 's-resize-2'); img.setAttribute('width', '10'); img.setAttribute('height', '17'); } else { img.setAttribute('src', ''); img.setAttribute('alt', 's-resize-1'); img.setAttribute('width', '17'); img.setAttribute('height', '10'); } return false; } } })();