浏览器滚动条美化

这款插件可以让你美化浏览器滚动条,提供了大、中、小三种滚动条宽度和浅色、深色、跟随系统主题三种颜色选择。

// ==UserScript==
// @name         浏览器滚动条美化
// @description  这款插件可以让你美化浏览器滚动条,提供了大、中、小三种滚动条宽度和浅色、深色、跟随系统主题三种颜色选择。
// @version      3.0
// @author       柒刻
// @icon         
// @match        *://*/*
// @grant        GM_addStyle
// @grant        GM_registerMenuCommand
// @grant        GM_getValue
// @grant        GM_setValue
// @license      MIT
// @namespace https://gf.qytechs.cn/users/1067482
// ==/UserScript==

(function() {
    'use strict';

    // 获取保存的滚动条宽度,如果没有则默认为10PX
    let scrollbarWidth = GM_getValue('scrollbarWidth', 10);
    // 获取保存的滚动条颜色主题,如果没有则默认为跟随系统
    let scrollbarColorTheme = GM_getValue('scrollbarColorTheme', 'system');

    // 应用滚动条样式
    applyScrollbarStyle(scrollbarWidth, scrollbarColorTheme);

    // 注册(不可用)设置菜单命令
    GM_registerMenuCommand('设置', () => {
        // 弹出设置窗口
        showSettingsPopup();
    });

    // 监听系统主题模式变化
    window.matchMedia('(prefers-color-scheme: dark)').addEventListener('change', e => {
        // 当系统主题模式发生变化时,重新应用滚动条样式
        scrollbarColorTheme = e.matches ? 'dark' : 'light';
        applyScrollbarStyle(scrollbarWidth, scrollbarColorTheme);
    });

    // 应用滚动条样式的函数
    function applyScrollbarStyle(width, theme) {
        // 获取滚动条颜色
        const scrollbarColor = getScrollbarColor(theme);

        // 添加自定义样式
        GM_addStyle(`
            *::-webkit-scrollbar {
                width: ${width}px!important;
                height: ${width}px!important;
            }
            *::-webkit-scrollbar-thumb {
                background-color: ${scrollbarColor} !important;
                border-radius: 5px; /* 添加圆角属性 */
            }
        `);
    }

    // 弹出设置窗口的函数
    function showSettingsPopup() {
        // 创建背景遮罩
        const mask = document.createElement('div');
        mask.style.position = 'fixed';
        mask.style.top = '0';
        mask.style.left = '0';
        mask.style.width = '100%';
        mask.style.height = '100%';
        mask.style.backgroundColor = 'rgba(0, 0, 0, 0.5)';
        mask.style.zIndex = '999999';
        document.body.appendChild(mask);

        // 创建设置窗口
        const popup = document.createElement('div');
        popup.innerHTML = `
            <div style="width: 300px; background-color: #fff; border-radius: 8px; position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%); z-index: 9999999; box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);">
                <div style="background-color: #007bff; color: #fff; text-align: center; font-weight: 700; font-size: 18px; padding: 10px 0; border-radius: 8px 8px 0 0;">菜单</div>
                <div style="padding: 20px;">
                    <button id="btn-width-16" style="width: 100%; padding: 10px 0; background-color: ${scrollbarWidth === 16 ? '#007bff' : '#e9ecef'}; color: ${scrollbarWidth === 16 ? '#fff' : '#495057'}; border: none; border-radius: 5px; cursor: pointer; margin-bottom: 16px;" data-width="16">大-16PX</button>
                    <button id="btn-width-10" style="width: 100%; padding: 10px 0; background-color: ${scrollbarWidth === 10 ? '#007bff' : '#e9ecef'}; color: ${scrollbarWidth === 10 ? '#fff' : '#495057'}; border: none; border-radius: 5px; cursor: pointer; margin-bottom: 10px;" data-width="10">中-10PX</button>
                    <button id="btn-width-6" style="width: 100%; padding: 10px 0; background-color: ${scrollbarWidth === 6 ? '#007bff' : '#e9ecef'}; color: ${scrollbarWidth === 6 ? '#fff' : '#495057'}; border: none; border-radius: 5px; cursor: pointer;" data-width="6">小-6PX</button>
                    <div style="display: flex; justify-content: space-between; align-items: center; margin-top: 20px;">
                        <button id="btn-theme-light" style="width: calc(100% / 3 - 10px); padding: 10px 0; background-color: ${scrollbarColorTheme === 'light' ? '#007bff' : '#e9ecef'}; color: ${scrollbarColorTheme === 'light' ? '#fff' : '#495057'}; border: none; border-radius: 5px; cursor: pointer;" data-theme="light">浅色主题</button>
                        <button id="btn-theme-dark" style="width: calc(100% / 3 - 10px); padding: 10px 0; background-color: ${scrollbarColorTheme === 'dark' ? '#007bff' : '#e9ecef'}; color: ${scrollbarColorTheme === 'dark' ? '#fff' : '#495057'}; border: none; border-radius: 5px; cursor: pointer;" data-theme="dark">深色主题</button>
                        <button id="btn-theme-system" style="width: calc(100% / 3 - 10px); padding: 10px 0; background-color: ${scrollbarColorTheme === 'system' ? '#007bff' : '#e9ecef'}; color: ${scrollbarColorTheme === 'system' ? '#fff' : '#495057'}; border: none; border-radius: 5px; cursor: pointer;" data-theme="system">跟随系统</button>
                    </div>
                </div>
                <div style="background-color: #007bff; color: #fff; text-align: center; font-weight: 700; font-size: 18px; padding: 10px 0; border-radius: 0 0 8px 8px; cursor: pointer;" id="close-settings-popup">关闭</div>
            </div>
        `;
        document.body.appendChild(popup);

        // 设置按钮点击事件
        const buttons = popup.querySelectorAll('button');
        buttons.forEach(button => {
            button.addEventListener('click', () => {
                const width = button.getAttribute('data-width');
                const theme = button.getAttribute('data-theme');
                // 更新设置
                if (width) {
                    // 更新滚动条宽度
                    scrollbarWidth = parseInt(width);
                    // 保存选择的滚动条宽度
                    GM_setValue('scrollbarWidth', scrollbarWidth);
                }
                if (theme) {
                    // 更新滚动条颜色主题
                    scrollbarColorTheme = theme;
                    // 保存选择的滚动条颜色主题
                    GM_setValue('scrollbarColorTheme', scrollbarColorTheme);
                }
                // 应用新的滚动条样式
                applyScrollbarStyle(scrollbarWidth, scrollbarColorTheme);
                // 更新按钮样式以突出显示选中的按钮
                updateButtonStyles();
            });
        });

        // 关闭设置窗口按钮点击事件
        const closeButton = popup.querySelector('#close-settings-popup');
        closeButton.addEventListener('click', () => {
            // 移除设置窗口和背景遮罩
            document.body.removeChild(mask);
            document.body.removeChild(popup);
        });

        // 背景遮罩点击事件
        mask.addEventListener('click', () => {
            // 移除设置窗口和背景遮罩
            document.body.removeChild(mask);
            document.body.removeChild(popup);
        });

        // 更新按钮样式以突出显示选中的按钮
        updateButtonStyles();
    }

    // 更新按钮样式以突出显示选中的按钮
    function updateButtonStyles() {
        // 更新滚动条宽度按钮样式
        updateButtonStyle('btn-width-16', scrollbarWidth === 16);
        updateButtonStyle('btn-width-10', scrollbarWidth === 10);
        updateButtonStyle('btn-width-6', scrollbarWidth === 6);

        // 更新滚动条颜色主题按钮样式
        updateButtonStyle('btn-theme-light', scrollbarColorTheme === 'light');
        updateButtonStyle('btn-theme-dark', scrollbarColorTheme === 'dark');
        updateButtonStyle('btn-theme-system', scrollbarColorTheme === 'system');
    }

    // 更新按钮样式
    function updateButtonStyle(buttonId, isSelected) {
        const button = document.getElementById(buttonId);
        if (button) {
            button.style.backgroundColor = isSelected ? '#007bff' : '#e9ecef';
            button.style.color = isSelected ? '#fff' : '#495057';
        }
    }

    // 获取滚动条颜色
    function getScrollbarColor(theme) {
        let color;
        if (theme === 'light') {
            color = '#CCC'; // 浅色主题颜色为浅灰色
        } else if (theme === 'dark') {
            color = '#444'; // 深色主题颜色为深灰色
        } else {
            // 跟随系统主题,根据系统主题设置颜色
            const systemTheme = window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'light';
            if (systemTheme === 'dark') {
                color = '#444'; // 深色主题颜色为深灰色
            } else {
                color = '#CCC'; // 浅色主题颜色为浅灰色
            }
        }
        return color;
    }
})();



QingJ © 2025

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