针对必应搜索的首页进行体验优化,隐藏繁杂的新闻资讯、今日热点等内容,可根据选项进行个性化的配置,还你一个干净简洁的必应搜索页面!
// ==UserScript==
// @name 必应搜索首页净化
// @namespace BingSearchHomeClean
// @version 1.3.2
// @description 针对必应搜索的首页进行体验优化,隐藏繁杂的新闻资讯、今日热点等内容,可根据选项进行个性化的配置,还你一个干净简洁的必应搜索页面!
// @author Lee
// @match *://*.bing.com/*
// @exclude /^https?:\/\/.*bing\.com\/.+\?[a-z]+=.+/
// @grant GM_registerMenuCommand
// @license GPL-3.0
// @icon 
// ==/UserScript==
(function () {
'use strict';
let userSettings = {
hideScrollContainer: true,
hideHeader: true,
hideMicrophone: true,
hideGold: true,
hideQrCode: true,
hideScrollbar: true,
hideInputTip: true,
hideHotNewsInput: true,
hideMobilePhoneLogo: true,
hideQrCodeMobile: true,
hideHotNews: true,
hideSearchEdition: true,
};
// 初始化用户设置,没有则创建默认设置
function initUserSettings() {
if (localStorage.getItem('bingUserSettings')) {
userSettings = JSON.parse(localStorage.getItem('bingUserSettings'));
} else {
localStorage.setItem('bingUserSettings', JSON.stringify(userSettings));
}
}
initUserSettings();
// 注册设置面板
function registerMenuCommand() {
GM_registerMenuCommand('自定义隐藏栏目', () => {
// 解决多次点击设置项导致无法关闭面板的问题
if (document.querySelector('.setting__panel')) {
return;
}
const settingsPanel = document.createElement('div');
settingsPanel.innerHTML = `
<div class="setting__panel">
<h4 class="setting__panel__title">选择要隐藏的栏目</h4>
<label><input type="checkbox" id="hideScrollContainer" ${userSettings.hideScrollContainer ? 'checked' : ''}>隐藏发现内容</label>
<label><input type="checkbox" id="hideHeader" ${userSettings.hideHeader ? 'checked' : ''}>隐藏图片/视频等头部五栏</label>
<label><input type="checkbox" id="hideGold" ${userSettings.hideGold ? 'checked' : ''}>隐藏奖杯数</label>
<label><input type="checkbox" id="hideQrCode" ${userSettings.hideQrCode ? 'checked' : ''}>隐藏二维码</label>
<label><input type="checkbox" id="hideInputTip" ${userSettings.hideInputTip ? 'checked' : ''}>隐藏输入框提示</label>
<label><input type="checkbox" id="hideHotNewsInput" ${userSettings.hideHotNewsInput ? 'checked' : ''}>隐藏输入框内今日热点</label>
<label><input type="checkbox" id="hideMicrophone" ${userSettings.hideMicrophone ? 'checked' : ''}>隐藏输入框麦克风图标</label>
<label><input type="checkbox" id="hideHotNews" ${userSettings.hideHotNews ? 'checked' : ''}>隐藏今日热点</label>
<label><input type="checkbox" id="hideSearchEdition" ${userSettings.hideSearchEdition ? 'checked' : ''}>隐藏国内外版本</label>
<button id="closeSetting" class="setting__panel__close">关闭设置</button>
</div>`;
document.body.appendChild(settingsPanel);
const userStyleSheet = document.createElement('style');
userStyleSheet.id = 'userStyleSheet';
userStyleSheet.innerHTML = `
.setting__panel {
position: fixed;
top: 10%;
right: 10px;
z-index: 9999;
width: 300px;
padding: 10px;
background-color: #fff;
border: 1px solid #ccc;
border-radius: 8px;
}
.setting__panel__title {
margin: 0 0 12px 0;
text-align: center;
}
label {
display: block;
cursor: pointer;
}
input {
margin-right: 6px;
}
.setting__panel__close {
width: 100%;
margin-top: 10px;
cursor: pointer;
}
`;
document.head.appendChild(userStyleSheet);
const list = ['hideScrollContainer', 'hideHeader', 'hideMicrophone', 'hideGold', 'hideQrCode', 'hideScrollbar', 'hideInputTip', 'hideHotNewsInput', 'hideMobilePhoneLogo', 'hideQrCodeMobile', 'hideHotNews', 'hideSearchEdition'];
list.forEach((id) => {
const el = document.getElementById(id);
if (el) {
el.addEventListener('change', function (e) {
userSettings[id] = e.target.checked;
localStorage.setItem('bingUserSettings', JSON.stringify(userSettings));
startBingSearchClean();
});
}
});
document.getElementById('closeSetting').addEventListener('click', () => {
document.body.removeChild(settingsPanel);
});
});
}
registerMenuCommand();
// 执行净化操作
function startBingSearchClean() {
// 发现内容
const container = document.querySelector('#scroll_cont');
if (container) {
userSettings.hideScrollContainer ? (container.style.display = 'none') : (container.style.display = 'revert');
}
// 头部五栏
const headerSection = document.querySelector('.scope_cont');
if (headerSection) {
userSettings.hideHeader ? (headerSection.style.display = 'none') : (headerSection.style.display = 'revert');
}
// 输入框麦克风图标
const microphone = document.querySelector('.mic_cont.icon');
if (microphone) {
userSettings.hideMicrophone ? (microphone.style.display = 'none') : (microphone.style.display = 'inline-block');
}
// 奖杯数
const gold = document.querySelector('#id_rh_w');
if (gold) {
userSettings.hideGold ? (gold.style.display = 'none') : (gold.style.display = 'revert');
}
// 必应app二维码
const qrCode = document.querySelector('#id_qrcode');
if (qrCode) {
userSettings.hideQrCode ? (qrCode.style.display = 'none') : (qrCode.style.display = 'revert');
}
// 隐藏溢出滚动条
const scrollbar = document.documentElement;
if (scrollbar && container) {
userSettings.hideScrollContainer ? (scrollbar.style.overflow = 'hidden') : (scrollbar.style.overflow = 'auto');
}
// 输入框内提示
const inputTip = document.querySelector('.sb_form_placeholder');
if (inputTip) {
userSettings.hideInputTip ? (inputTip.style.display = 'none') : (inputTip.style.display = 'revert');
}
// 输入框内今日热点
const hotNewsInput = document.querySelector('#sa_pn_block');
if (hotNewsInput) {
userSettings.hideHotNewsInput ? (hotNewsInput.style.display = 'none') : (hotNewsInput.style.display = 'revert');
}
// 今日上的热点
const hotNews = document.querySelector('.below_sbox');
if (hotNews) {
userSettings.hideHotNews ? (hotNews.style.display = 'none') : (hotNews.style.display = 'revert');
}
// 国内外搜索不同版本
const searchEdition = document.querySelector('#est_switch');
if (searchEdition) {
userSettings.hideSearchEdition ? (searchEdition.style.display = 'none') : (searchEdition.style.display = 'revert');
}
// 搜索结果右侧手机端标识
const mobilePhoneLogo = document.querySelector('.id_mobile');
if (mobilePhoneLogo) {
mobilePhoneLogo.style.display = 'none';
}
// 下载手机端二维码推荐
const qrCodeMobile = document.querySelector('#id_qrcode_popup_container');
if (qrCodeMobile) {
qrCodeMobile.style.display = 'none';
}
}
// 初次加载页面时就执行净化操作
const observer = new MutationObserver(() => {
startBingSearchClean();
});
observer.observe(document.body, { childList: true, subtree: true });
})();