• CSS3自定义滚动条样式


    转载自ranyonsue
    自定义滚动条实现

    此部分针对webkit内核的浏览器,使用伪类来改变滚动条的默认样式,详情如下:

    滚动条组成部分

    1. ::-webkit-scrollbar 滚动条整体部分

    2. ::-webkit-scrollbar-thumb 滚动条里面的小方块,能向上向下移动(或向左向右移动)

    3. ::-webkit-scrollbar-track 滚动条的轨道(里面装有Thumb)

    4. ::-webkit-scrollbar-button 滚动条的轨道的两端按钮,由于通过点击微调小方块的位置。

    5. ::-webkit-scrollbar-track-piece 内层轨道,滚动条中间部分

    6. ::-webkit-scrollbar-corner 边角,即垂直滚动条和水平滚动条相交的地方

    7. ::-webkit-resizer 两个滚动条的交汇处上用于拖动调整元素大小的小控件

    滚动条组成结构图如下:

    其他设置项:

    :horizontal
    //horizontal伪类适用于任何水平方向上的滚动条

    :vertical
    //vertical伪类适用于任何垂直方向的滚动条

    :decrement
    //decrement伪类适用于按钮和轨道碎片。表示递减的按钮或轨道碎片,例如可以使区域向上或者向右移动的区域和按钮

    :increment
    //increment伪类适用于按钮和轨道碎片。表示递增的按钮或轨道碎片,例如可以使区域向下或者向左移动的区域和按钮

    :start
    //start伪类适用于按钮和轨道碎片。表示对象(按钮 轨道碎片)是否放在滑块的前面

    :end
    //end伪类适用于按钮和轨道碎片。表示对象(按钮 轨道碎片)是否放在滑块的后面

    :double-button
    //double-button伪类适用于按钮和轨道碎片。判断轨道结束的位置是否是一对按钮。也就是轨道碎片紧挨着一对在一起的按钮。

    :single-button
    //single-button伪类适用于按钮和轨道碎片。判断轨道结束的位置是否是一个按钮。也就是轨道碎片紧挨着一个单独的按钮。

    :no-button
    no-button伪类表示轨道结束的位置没有按钮。

    :corner-present
    //corner-present伪类表示滚动条的角落是否存在。

    :window-inactive
    //适用于所有滚动条,表示包含滚动条的区域,焦点不在该窗口的时候。

    ::-webkit-scrollbar-track-piece:start {
    /滚动条上半边或左半边/
    }

    ::-webkit-scrollbar-thumb:window-inactive {
    /当焦点不在当前区域滑块的状态/
    }

    ::-webkit-scrollbar-button:horizontal:decrement:hover {
    /当鼠标在水平滚动条下面的按钮上的状态/
    }

    实例:

    Html

        <div class="scrollbar"></div>
    

    Css

    .test{

     50px;
    
    height: 200px;
    
    overflow: auto;
    
    float: left;
    
    margin: 5px;
    
    border: none;
    

    }

    .scrollbar{

     30px;
    
    height: 300px;
    
    margin: 0 auto;
    

    }

    .test-1::-webkit-scrollbar {/滚动条整体样式/

         10px;     /*高宽分别对应横竖滚动条的尺寸*/
    
        height: 1px;
    
    }
    

    .test-1::-webkit-scrollbar-thumb {/滚动条里面小方块/

        border-radius: 10px;
    
         -webkit-box-shadow: inset 0 0 5px rgba(0,0,0,0.2);
    
        background: #535353;
    
    }
    

    .test-1::-webkit-scrollbar-track {/滚动条里面轨道/

        -webkit-box-shadow: inset 0 0 5px rgba(0,0,0,0.2);
    
        border-radius: 10px;
    
        background: #EDEDED;
    

    }

    效果如下如:

    注意只在chrome下有效!

    ::-webkit-scrollbar{}这种写法改变的是全局的滚动条。

  • 相关阅读:
    20174303刘金晖 Exp 8 Web基础
    2019-2020-2 网络对抗技术 20174303刘金晖 Exp7 网络欺诈防范
    20174303刘金晖 Exp6 MSF基础应用
    20174303刘金晖 Exp5 信息搜集与漏洞扫描
    20174303刘金晖 Exp4 恶意代码分析
    2019-2020-2 20174303刘金晖 Exp3 免杀原理与实践
    2019-2020-2 20174303刘金晖 Exp2 后门原理与实践
    2019-2020-2 20174303刘金晖 Exp1 PC平台逆向破解
    20174307周俊锴《网络对抗技术》Exp9 Web安全基础
    20174307周俊锴Exp8 Web基础
  • 原文地址:https://www.cnblogs.com/jaycethanks/p/12506994.html
Copyright © 2020-2023  润新知