必应中国体验优化

提升必应中国搜索的简洁与高效!

// ==UserScript==
// @name               Bing China Search Optimization
// @name:zh-CN         必应中国体验优化
// @name:zh-TW         必應中國體驗優化
// @namespace          https://www.imxiaoanag.com
// @version            1.0.2
// @description        Make your Bing China searches cleaner and more efficient!
// @description:zh-CN  提升必应中国搜索的简洁与高效!
// @description:zh-TW  提升必應中國(對岸版)搜尋的簡潔與高效!
// @author             imxiaoanag
// @match              http*://cn.bing.com/*
// @icon               
// @grant              GM_getValue
// @grant              GM_setValue
// @run-at             document-start
// @license            MIT
// ==/UserScript==

(function() {
    'use strict';

    const removeElements = [
        'li.b_ad',
        'div.sb_adTA',
        'li#adstop_gradiant_separator'
    ];

    function removeAds() {
        removeElements.forEach(selector => {
            const elements = document.querySelectorAll(selector);
            elements.forEach(element => {
                element.remove();
            });
        });
    }

    function cleanURI(url) {
        const urlObj = new URL(url);
        if (urlObj.hostname === 'cn.bing.com' && urlObj.pathname === '/search') {
            const searchQuery = urlObj.searchParams.get('q');
            const firstParam = urlObj.searchParams.get('first');

            if (searchQuery) {
                let cleanUrl = `https://cn.bing.com/search?q=${encodeURIComponent(searchQuery)}`;
                if (firstParam) {
                    cleanUrl += `&first=${firstParam}`;
                }
                return cleanUrl;
            }
        }
    }

    function checkAndCleanUrl() {
        const currentUrl = window.location.href;
        const cleanedUrl = cleanURI(currentUrl);

        if (cleanedUrl !== currentUrl) {
            window.history.replaceState(null, '', cleanedUrl);
        }
    }

    const defaultExcludedDomains = ['https://[^/]+\.csdn\.net', 'https://[^/]+\.jianshu\.com'];
    let excludedDomains = GM_getValue('excludedDomains', defaultExcludedDomains);

    function removeSpecificDomainResults() {
        excludedDomains.forEach(domainPattern => {
            const regex = new RegExp(domainPattern);
            const domainElements = document.querySelectorAll('a[href]');
            domainElements.forEach(element => {
                if (regex.test(element.href)) {
                    const liElement = element.closest('li.b_algo');
                    if (liElement) {
                        liElement.remove();
                    }
                }
            });
        });
    }

    function createSettingsUI() {
        const settingsDiv = document.createElement('div');
        settingsDiv.id = 'bingSettingsUI';
        settingsDiv.style.position = 'fixed';
        settingsDiv.style.bottom = '10px';
        settingsDiv.style.right = '60px'; // Adjusted to 60px to avoid overlapping with toggleButton
        settingsDiv.style.width = '320px';
        settingsDiv.style.height = 'auto';
        settingsDiv.style.border = '1px solid #ccc';
        settingsDiv.style.backgroundColor = '#fff';
        settingsDiv.style.padding = '10px';
        settingsDiv.style.zIndex = '10002';
        settingsDiv.style.boxShadow = '2px 2px 10px rgba(0, 0, 0, 0.2)';
        settingsDiv.style.borderRadius = '5px';
        settingsDiv.style.fontFamily = 'Arial, sans-serif';

        const settingsTitle = document.createElement('h3');
        settingsTitle.innerText = '排除域名设置'; // Default to Simplified Chinese
        settingsDiv.appendChild(settingsTitle);

        const domainList = document.createElement('ul');
        domainList.id = 'excludedDomainsList';
        domainList.style.listStyleType = 'none';
        domainList.style.padding = '0';
        domainList.style.margin = '0';

        excludedDomains.forEach((domain, index) => {
            const li = document.createElement('li');
            li.style.display = 'flex';
            li.style.alignItems = 'center';
            li.style.justifyContent = 'space-between'; // Ensure elements are right-aligned
            li.style.marginBottom = '5px';

            const input = document.createElement('input');
            input.type = 'text';
            input.value = domain;
            input.style.width = '250px';
            input.style.padding = '5px';
            input.style.border = '1px solid #ccc';
            input.style.borderRadius = '3px';

            const removeButton = document.createElement('button');
            removeButton.innerText = '删除'; // Default to Simplified Chinese
            removeButton.style.width = '60px'; // 统一设置为60px
            removeButton.style.padding = '5px 10px';
            removeButton.style.border = 'none';
            removeButton.style.backgroundColor = '#008CBA'; // Changed to teal color
            removeButton.style.color = 'white'; // Changed to white color
            removeButton.style.borderRadius = '3px';
            removeButton.style.cursor = 'pointer';
            removeButton.onclick = () => {
                excludedDomains.splice(index, 1);
                li.remove();
                GM_setValue('excludedDomains', excludedDomains);
            };

            li.appendChild(input);
            li.appendChild(removeButton);
            domainList.appendChild(li);
        });

        settingsDiv.appendChild(domainList);

        const addDomainWrapper = document.createElement('div');
        addDomainWrapper.style.display = 'flex';
        addDomainWrapper.style.alignItems = 'center';
        addDomainWrapper.style.justifyContent = 'space-between'; // Ensure elements are right-aligned
        addDomainWrapper.style.marginBottom = '10px';

        const addDomainInput = document.createElement('input');
        addDomainInput.type = 'text';
        addDomainInput.id = 'addExcludedDomainInput';
        addDomainInput.placeholder = '添加新域名'; // Default to Simplified Chinese
        addDomainInput.style.width = '250px';
        addDomainInput.style.padding = '5px';
        addDomainInput.style.border = '1px solid #ccc';
        addDomainInput.style.borderRadius = '3px';
        addDomainWrapper.appendChild(addDomainInput);

        const addButton = document.createElement('button');
        addButton.innerText = '添加'; // Default to Simplified Chinese
        addButton.style.width = '60px'; // 统一设置为60px
        addButton.style.padding = '5px 10px';
        addButton.style.border = 'none';
        addButton.style.backgroundColor = '#008CBA'; // Changed to teal color
        addButton.style.color = 'white'; // Changed to white color
        addButton.style.borderRadius = '3px';
        addButton.style.cursor = 'pointer';
        addButton.onclick = () => {
            const newDomain = addDomainInput.value.trim();
            if (newDomain && !excludedDomains.includes(newDomain)) {
                excludedDomains.push(newDomain);
                const li = document.createElement('li');
                li.style.display = 'flex';
                li.style.alignItems = 'center';
                li.style.justifyContent = 'space-between'; // Ensure elements are right-aligned
                li.style.marginBottom = '5px';

                const input = document.createElement('input');
                input.type = 'text';
                input.value = newDomain;
                input.style.width = '250px';
                input.style.padding = '5px';
                input.style.marginRight = '5px';
                input.style.border = '1px solid #ccc';
                input.style.borderRadius = '3px';

                const removeButton = document.createElement('button');
                removeButton.innerText = '删除'; // Default to Simplified Chinese
                removeButton.style.width = '60px'; // 统一设置为60px
                removeButton.style.padding = '5px 10px';
                removeButton.style.border = 'none';
                removeButton.style.backgroundColor = '#008CBA'; // Changed to teal color
                removeButton.style.color = 'white'; // Changed to white color
                removeButton.style.borderRadius = '3px';
                removeButton.style.cursor = 'pointer';
                removeButton.onclick = () => {
                    const index = excludedDomains.indexOf(newDomain);
                    if (index !== -1) {
                        excludedDomains.splice(index, 1);
                        li.remove();
                        GM_setValue('excludedDomains', excludedDomains);
                    }
                };

                li.appendChild(input);
                li.appendChild(removeButton);
                domainList.appendChild(li);
                addDomainInput.value = '';
                GM_setValue('excludedDomains', excludedDomains);
            }
        };
        addDomainWrapper.appendChild(addButton);

        settingsDiv.appendChild(addDomainWrapper);

        const saveButton = document.createElement('button');
        saveButton.id = 'bingSaveButton';
        saveButton.innerText = '保存'; // Default to Simplified Chinese
        saveButton.style.width = '45%';
        saveButton.style.padding = '10px';
        saveButton.style.margin = '10px 5px 0 0';
        saveButton.style.border = 'none';
        saveButton.style.backgroundColor = '#008CBA'; // Changed to teal color
        saveButton.style.color = 'white'; // Changed to white color
        saveButton.style.borderRadius = '3px';
        saveButton.style.cursor = 'pointer';
        saveButton.onclick = () => {
            const domainInputs = document.querySelectorAll('#excludedDomainsList input[type="text"]');
            excludedDomains = Array.from(domainInputs).map(input => input.value.trim()).filter(domain => domain.length > 0);
            GM_setValue('excludedDomains', excludedDomains);
            window.location.reload();
        };
        settingsDiv.appendChild(saveButton);

        const resetButton = document.createElement('button');
        resetButton.id = 'bingResetButton';
        resetButton.innerText = '重置'; // Default to Simplified Chinese
        resetButton.style.width = '45%';
        resetButton.style.padding = '10px';
        resetButton.style.margin = '10px 0 0 5px';
        resetButton.style.border = 'none';
        resetButton.style.backgroundColor = '#008CBA'; // Changed to teal color
        resetButton.style.color = 'white'; // Changed to white color
        resetButton.style.borderRadius = '3px';
        resetButton.style.cursor = 'pointer';
        resetButton.onclick = () => {
            excludedDomains = defaultExcludedDomains;
            GM_setValue('excludedDomains', excludedDomains);
            domainList.innerHTML = ''; // Clear the list

            excludedDomains.forEach(domain => {
                const li = document.createElement('li');
                li.style.display = 'flex';
                li.style.alignItems = 'center';
                li.style.justifyContent = 'space-between'; // Ensure elements are right-aligned
                li.style.marginBottom = '5px';

                const input = document.createElement('input');
                input.type = 'text';
                input.value = domain;
                input.style.width = '250px';
                input.style.padding = '5px';
                input.style.marginRight = '5px';
                input.style.border = '1px solid #ccc';
                input.style.borderRadius = '3px';

                const removeButton = document.createElement('button');
                removeButton.innerText = '删除'; // Default to Simplified Chinese
                removeButton.style.width = '60px'; // 统一设置为60px
                removeButton.style.padding = '5px 10px';
                removeButton.style.border = 'none';
                removeButton.style.backgroundColor = '#008CBA'; // Changed to teal color
                removeButton.style.color = 'white'; // Changed to white color
                removeButton.style.borderRadius = '3px';
                removeButton.style.cursor = 'pointer';
                removeButton.onclick = () => {
                    const index = excludedDomains.indexOf(domain);
                    if (index !== -1) {
                        excludedDomains.splice(index, 1);
                        li.remove();
                        GM_setValue('excludedDomains', excludedDomains);
                    }
                };

                li.appendChild(input);
                li.appendChild(removeButton);
                domainList.appendChild(li);
            });
            window.location.reload();
        };
        settingsDiv.appendChild(resetButton);

        // Detect language and update text accordingly
        const userLang = navigator.language || navigator.userLanguage;
        let localizedTexts = {
            settingsTitle: '排除域名设置',
            addDomainInputPlaceholder: '添加新域名',
            addButton: '添加',
            saveButton: '保存',
            resetButton: '重置',
            removeButton: '删除'
        };

        if (userLang.startsWith('zh')) {
            if (userLang === 'zh-TW') {
                localizedTexts = {
                    settingsTitle: '排除域名設定',
                    addDomainInputPlaceholder: '新增新域名',
                    addButton: '新增',
                    saveButton: '儲存',
                    resetButton: '重置',
                    removeButton: '刪除'
                };
            }
        } else {
            localizedTexts = {
                settingsTitle: 'Excluded Domains Settings',
                addDomainInputPlaceholder: 'Add new domain',
                addButton: 'Add',
                saveButton: 'Save',
                resetButton: 'Reset',
                removeButton: 'Delete'
            };
        }

        settingsTitle.innerText = localizedTexts.settingsTitle;
        addDomainInput.placeholder = localizedTexts.addDomainInputPlaceholder;
        addButton.innerText = localizedTexts.addButton;
        saveButton.innerText = localizedTexts.saveButton;
        resetButton.innerText = localizedTexts.resetButton;

        // 修改:只对非特定ID的按钮设置文本和宽度
        document.querySelectorAll('button').forEach((button, index) => {
            if (button.id !== 'bingSaveButton' && button.id !== 'bingResetButton' && button.id !== 'bingToggleButton') {
                button.innerText = localizedTexts.removeButton;
                button.style.width = '60px'; // 统一设置为60px
            }
        });

        document.body.appendChild(settingsDiv);
    }

    function createToggleButton() {
        const toggleButton = document.createElement('button');
        toggleButton.id = 'bingToggleButton';
        toggleButton.style.position = 'fixed';
        toggleButton.style.bottom = '10px';
        toggleButton.style.right = '10px';
        toggleButton.style.width = '40px';
        toggleButton.style.height = '40px';
        toggleButton.style.borderRadius = '50%';
        toggleButton.style.backgroundColor = '#008CBA';
        toggleButton.style.border = 'none';
        toggleButton.style.color = 'white';
        toggleButton.style.zIndex = '10001';
        toggleButton.innerText = '⚙';
        toggleButton.style.fontSize = '18px';

        toggleButton.onclick = () => {
            const settingsDiv = document.getElementById('bingSettingsUI');
            if (settingsDiv) {
                document.body.removeChild(settingsDiv);
            } else {
                createSettingsUI();
            }
        };
        document.body.appendChild(toggleButton);
    }

    let lastUrl = window.location.href;
    new MutationObserver(() => {
        const currentUrl = window.location.href;
        if (currentUrl !== lastUrl) {
            lastUrl = currentUrl;
            checkAndCleanUrl();
            removeAds();
            window.location.reload();
        }
    }).observe(document, {subtree: true, childList: true, attributes: true, characterData: true});

    checkAndCleanUrl();
    createToggleButton();

    window.onload = () => {
        removeAds();
        removeSpecificDomainResults();
    };
})();

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址