简单滚动条美化

简单滚动条美化,可自定义设置滚动条宽度、颜色

// ==UserScript==
// @name 简单滚动条美化
// @description 简单滚动条美化,可自定义设置滚动条宽度、颜色
// @match *://*/*
// @version 0.5
// @namespace 犹科
// @grant GM_setValue
// @grant GM_getValue
// @grant GM_deleteValue
// @grant GM_registerMenuCommand
// @icon 
// @run-at document-start
// ==/UserScript==
(function() {
    'use strict';
    function buildOption(){
        return {
            width:GM_getValue("width") || 8,
            trackColor:GM_getValue("trackColor") || "#ffffff",
            trackColorRange:parseFloat(GM_getValue("trackColorRange") || 0),
            borderRadius:GM_getValue("borderRadius") || 4,
            borderWidth:GM_getValue("borderWidth") || 1,
            borderColor:GM_getValue("borderColor") || "#ffffff",
            borderColorRange:parseFloat(GM_getValue("borderColorRange") || 1),
            thumbColor:GM_getValue("thumbColor") || "#aaaaaa",
            thumbColorRange:parseFloat(GM_getValue("thumbColorRange") || 1),
            thumbHverColor:GM_getValue("thumbHverColor") || "#888888",
            thumbHverColorRange:parseFloat(GM_getValue("thumbHverColorRange") || 1),
            thumbActiveColor:GM_getValue("thumbActiveColor") || "#666666",
            thumbActiveColorRange:parseFloat(GM_getValue("thumbActiveColorRange") || 1)
        };
    }

    let option = buildOption();
    let styleId = "easy-scrollbar-beautify";
    let settingId = "easy-scrollbar-beautify-setting";
    let settingHtml = `
    <html>
      <head>
          <style>
            body{
              margin: 0;
              font-size: 16px;
            }
            .panel{
              padding:10px;
            }
            .title{
              text-align: center;
              font-size: 20px;
              padding-bottom: 10px;
            }
            #reset{
              position: absolute;
              top: 14px;
              right: 10px;
              width: 20px;
              height: 20px;
              cursor: pointer;
              background-image: url("");
              background-repeat: no-repeat;
              background-size: 100%;
            }
            #save{
              cursor: pointer;
              color: #fff;
              background: #2196f3;
              border: 0;
              text-align: center;
              padding: 8px 35px;
              margin-right: 5px;
            }
            #save:active{
              background: #1e88e5;
            }
            #close{
              cursor: pointer;
              color: #000;
              background: #eeeeee;
              border: 0;
              text-align: center;
              padding: 8px 35px;
              margin-left: 5px;
            }
            #close:active{
              background: #e0e0e0;
            }
            input{
              outline: none;
              width: 50px;
              height: 28px;
              border: 1px solid #ccc;
            }
            input[type="number"]{
              padding: 2px 5px;
              margin: 0 2px;
            }
            input[type="color"]{
                position: absolute;
                top: -5px;
                left: -5px;
                border: 0;
                padding: 0;
                width: 120%;
                height: 140%;
            }
            input[type="range"]{
                vertical-align: middle;
                width: 66px;
                margin: 0;
                border: 0;
            }
            .color-picker{
                position: relative;
                display: inline-block;
                margin: 0 2px;
                width: 48px;
                height: 26px;
                vertical-align: middle;
                border: 1px solid #ccc;
                overflow: hidden;
            }
            .color-picker .show-bg{
                display: block;
                width: 100%;
                height: 100%;
                background-image: url("");
                background-repeat: repeat;
            }
            /* chrome */
            input::-webkit-outer-spin-button,
            input::-webkit-inner-spin-button {
                -webkit-appearance: none;
            }
            /* 火狐浏览器 */
            input[type="number"]{
                -moz-appearance: textfield;
            }
            .item{
                padding: 3px 0;
            }
            .bottom{
                padding-top: 10px;
            }
           </style>
      </head>
      <body>
          <div class="panel">
            <div class="title">设置</div>
            <div id="reset" title="重置"></div>
            <div class="item">
             <span>滚动条宽度</span>
             <input name="width" type="number" oninput="if(value.length>2)value=value.slice(0,2)" onblur="if(!value)value=`+option.width+`" value="`+option.width+`"/>
             <span>px</span>
            </div>
            <div class="item">
             <span>滚动槽颜色</span>
             <span class="color-picker">
               <input name="trackColor" type="color" value="`+option.trackColor+`" style="opacity: `+option.trackColorRange+`"/>
               <span class="show-bg"></span>
             </span>
             <input name="trackColorRange" type="range" min="0" max="1" step="0.1" value="`+option.trackColorRange+`"/>
            </div>
            <div class="item">
             <span>边框的圆角</span>
             <input name="borderRadius" type="number" oninput="if(value.length>2)value=value.slice(0,2)" onblur="if(!value)value=`+option.borderRadius+`" value="`+option.borderRadius+`"/>
             <span>px</span>
            </div>
            <div class="item">
             <span>边框的宽度</span>
             <input name="borderWidth" type="number" oninput="if(value.length>2)value=value.slice(0,2)" onblur="if(!value)value=`+option.borderWidth+`" value="`+option.borderWidth+`"/>
             <span>px</span>
            </div>
            <div class="item">
             <span>边框的颜色</span>
             <span class="color-picker">
               <input name="borderColor" type="color" value="`+option.borderColor+`" style="opacity: `+option.borderColorRange+`"/>
               <span class="show-bg"></span>
             </span>
             <input name="borderColorRange" type="range" min="0" max="1" step="0.1" value="`+option.borderColorRange+`"/>
            </div>
            <div class="item">
             <span>滚动条颜色</span>
             <span class="color-picker">
               <input name="thumbColor" type="color" value="`+option.thumbColor+`" style="opacity: `+option.thumbColorRange+`"/>
               <span class="show-bg"></span>
             </span>
             <input name="thumbColorRange" type="range" min="0" max="1" step="0.1" value="`+option.thumbColorRange+`"/>
            </div>
            <div class="item">
             <span>悬停时颜色</span>
             <span class="color-picker">
               <input name="thumbHverColor" type="color" value="`+option.thumbHverColor+`" style="opacity: `+option.thumbHverColorRange+`"/>
               <span class="show-bg"></span>
             </span>
             <input name="thumbHverColorRange" type="range" min="0" max="1" step="0.1" value="`+option.thumbHverColorRange+`"/>
            </div>
            <div class="item">
             <span>选中时颜色</span>
             <span class="color-picker">
               <input name="thumbActiveColor" type="color" value="`+option.thumbActiveColor+`" style="opacity: `+option.thumbActiveColorRange+`"/>
               <span class="show-bg"></span>
             </span>
             <input name="thumbActiveColorRange" type="range" min="0" max="1" step="0.1" value="`+option.thumbActiveColorRange+`"/>
            </div>
            <div class="bottom">
              <button type="button" id="save">确定</button>
              <button type="button" id="close">关闭</button>
            </div>
          </div>
      </body>
    </html>`;

    function changeColorPicker(colorName,rangeVal){
        let ifr = document.querySelector("#"+settingId);
        let ifrw = getIfrw(ifr);
        let ifrdoc = ifrw.document;
        let el = ifrdoc.querySelector("[name='"+colorName+"']");
        el.style.opacity = rangeVal;
    }

    function toHex(value){
        let num = value * 255;
        let hex = parseInt(num).toString(16);
        return hex ==="0"?"00":hex;
    }

    function getIfrw(ifr){
      return (ifr.contentWindow) ? ifr.contentWindow : (ifr.contentDocument.document) ? ifr.contentDocument.document : ifr.contentDocument;
    }

    function setting(){
        //顶层窗口页面才能显示设置窗口
        if(top !== self){
          return;
        }
        let body = document.body;
        let scrollbarSetting = body.querySelector("#"+settingId);
        if(!scrollbarSetting){
            // 创建iframe添加到页面底部,渲染设置页面,绑定事件
            let ifr = document.createElement("iframe");
            ifr.setAttribute("frameborder", "0");
            ifr.setAttribute("scrolling", "no");
            ifr.setAttribute("id", settingId);
            ifr.setAttribute("style", "position: fixed;top: 2px;right: 2px;width: 230px;height: 370px;background: #fff;border-radius: 10px;box-shadow: 0px 0px 6px 1px #666;z-index: 999999999;");
            body.appendChild(ifr);
            let ifrw = getIfrw(ifr);
            let ifrdoc = ifrw.document;
            ifrdoc.open();
            ifrdoc.write(settingHtml);
            ifrdoc.close();
            // 透明度改变事件
            ifrdoc.querySelector("[name='trackColorRange']").oninput=function(){
                changeColorPicker('trackColor',this.value);
            }
            ifrdoc.querySelector("[name='borderColorRange']").oninput=function(){
                changeColorPicker('borderColor',this.value);
            }
            ifrdoc.querySelector("[name='thumbColorRange']").oninput=function(){
                changeColorPicker('thumbColor',this.value);
            }
            ifrdoc.querySelector("[name='thumbHverColorRange']").oninput=function(){
                changeColorPicker('thumbHverColor',this.value);
            }
            ifrdoc.querySelector("[name='thumbActiveColorRange']").oninput=function(){
                changeColorPicker('thumbActiveColor',this.value);
            }
            // 重置点击事件
            ifrdoc.querySelector("#reset").onclick = function(){
              if (confirm("确定重置为默认设置?")) {
                let ifr = document.querySelector("#"+settingId);
                let ifrw = getIfrw(ifr);
                let tagElements = ifrw.document.getElementsByTagName('input');
                for (let i = 0; i < tagElements.length; i++){
                    let el = tagElements[i];
                    GM_deleteValue(el.getAttribute("name"));
                }
                let option = buildOption();
                for (let j = 0; j < tagElements.length; j++){
                    let _el = tagElements[j];
                    _el.value = option[_el.getAttribute("name")];
                }
                for (let k = 0; k < tagElements.length; k++){
                    let el = tagElements[k];
                    if(el.getAttribute("type") === "color"){
                        let rangeEl = ifrdoc.querySelector("[name='"+el.getAttribute("name")+"Range']");
                        el.style.opacity = rangeEl.value;
                    }
                }
              }
            };
            // 保存点击事件
            ifrdoc.querySelector("#save").onclick = function() {
                let ifr = document.querySelector("#"+settingId);
                let ifrw = getIfrw(ifr);
                let tagElements = ifrw.document.getElementsByTagName('input');
                for (let i = 0; i < tagElements.length; i++){
                    let el = tagElements[i];
                    GM_setValue(el.getAttribute("name"), el.value);
                }
                ifr.style.display = "none";
                setTimeout(function(){
                    alert("保存成功,刷新页面后生效。");
                },100);
            };
            // 关闭点击事件
            ifrdoc.querySelector("#close").onclick = function(){
                // 隐藏设置窗口,还原未保存设置
                let ifr = document.querySelector("#"+settingId);
                ifr.style.display = "none";
                let ifrw = getIfrw(ifr);
                let tagElements = ifrw.document.getElementsByTagName('input');
                let option = buildOption();
                for (let j = 0; j < tagElements.length; j++){
                   let el = tagElements[j];
                   el.value = option[el.getAttribute("name")];
                }
                for (let k = 0; k < tagElements.length; k++){
                    let el = tagElements[k];
                    if(el.getAttribute("type") === "color"){
                        let rangeEl = ifrdoc.querySelector("[name='"+el.getAttribute("name")+"Range']");
                        el.style.opacity = rangeEl.value;
                    }
                }
            };
        } else {
           // 显示设置窗口
           let ifr = document.querySelector("#"+settingId);
           ifr.style.display = "block";
        }
    }

    GM_registerMenuCommand("设置", setting);

    function buildStyle() {
        let option = buildOption();
        return `
        <style id="`+styleId+`" type="text/css" media="all">
        /* 滚动条整体宽度 */
        ::-webkit-scrollbar {
            -webkit-appearance: none;
            width: `+option.width+`px;
            height: `+option.width+`px;
        }
        /* 滚动条滑槽样式 */
        ::-webkit-scrollbar-track {
            background-color: `+option.trackColor+toHex(option.trackColorRange)+`;
        }
        /* 滚动条样式 */
        ::-webkit-scrollbar-thumb {
            border-radius: `+option.borderRadius+`px;
            border-width: `+option.borderWidth+`px;
            border-style: solid;
            border-color: `+option.borderColor+toHex(option.borderColorRange)+`;
            background-color: `+option.thumbColor+toHex(option.thumbColorRange)+`;
        }
        ::-webkit-scrollbar-thumb:hover{
            background-color: `+option.thumbHverColor+toHex(option.thumbHverColorRange)+`;
        }
        ::-webkit-scrollbar-thumb:active{
            background-color: `+option.thumbActiveColor+toHex(option.thumbActiveColorRange)+`;
        }
        /* 浏览器失焦的样式 */
        ::-webkit-scrollbar-thumb:window-inactive {
            background-color: `+option.thumbColor+toHex(option.thumbColorRange)+`;
        }
        </style>`;
    };
    try {
        document.documentElement.insertAdjacentHTML("afterBegin", buildStyle())
    } catch (err) {
        document.addEventListener ("DOMContentLoaded", function(){
          document.documentElement.insertAdjacentHTML("afterBegin", buildStyle())
        });
        return false
    }
})();

QingJ © 2025

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