zoukankan      html  css  js  c++  java
  • 转:CSS设置滚动条样式

    浏览器默认的滚动条样子太过屌丝了,得自己动手整整。记得IE浏览器有几个设置滚条的样式,不过比较鸡肋,只能设置颜色之类的,而且webkit下面也不支持。无意间看到网易邮箱的滚动条样子很好看,一开始以为是用div模拟的,结果一看,吼吼,正合我意,利用的CSS来设置的,而且是webkit浏览器的。

    得好好研究这几个属性下,才能自己动手改造。

    webkit浏览器css设置滚动条

    主要有下面7个属性

    1. ::-webkit-scrollbar 滚动条整体部分,可以设置宽度啥的
    2. ::-webkit-scrollbar-button 滚动条两端的按钮
    3. ::-webkit-scrollbar-track  外层轨道
    4. ::-webkit-scrollbar-track-piece  内层滚动槽
    5. ::-webkit-scrollbar-thumb 滚动的滑块
    6. ::-webkit-scrollbar-corner 边角
    7. ::-webkit-resizer 定义右下角拖动块的样式

    具体所指如图例

    上面是滚动条的主要几个设置属性,还有更详尽的CSS属性

    :horizontal 水平方向的滚动条

    :vertical 垂直 方向的滚动条

    :decrement 应用于按钮和内层轨道(track piece)。它用来指示按钮或者内层轨道是否会减小视窗的位置(比如,垂直滚动条的上面,水平滚动条的左边。)

    :increment decrement类似,用来指示按钮或内层轨道是否会增大视窗的位置(比如,垂直滚动条的下面和水平滚动条的右边。)

    :start 伪类也应用于按钮和滑块。它用来定义对象是否放到滑块的前面。

    :end 类似于start伪类,标识对象是否放到滑块的后面。

    :double-button  该伪类以用于按钮和内层轨道。用于判断一个按钮是不是放在滚动条同一端的一对按钮中的一个。对于内层轨道来说,它表示内层轨道是否紧靠一对按钮。

    :single-button 类似于double-button伪类。对按钮来说,它用于判断一个按钮是否自己独立的在滚动条的一段。对内层轨道来说,它表示内层轨道是否紧靠一个single-button。

    :no-button 用于内层轨道,表示内层轨道是否要滚动到滚动条的终端,比如,滚动条两端没有按钮的时候。

    :corner-present  用于所有滚动条轨道,指示滚动条圆角是否显示。

    :window-inactive 用于所有的滚动条轨道,指示应用滚动条的某个页面容器(元素)是否当前被激活。(在webkit最近的版本中,该伪类也可以用于::selection伪元素。webkit团队有计划扩展它并推动成为一个标准的伪类)

    写个实例demo吧(请在webkit浏览器下观看),不能光说不练。CSS也很简单。

    • /* 设置滚动条的样式 */
    • ::-webkit-scrollbar {
    • 12px;
    • }
    • /* 滚动槽 */
    • ::-webkit-scrollbar-track {
    • -webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0.3);
    • border-radius: 10px;
    • }
    • /* 滚动条滑块 */
    • ::-webkit-scrollbar-thumb {
    • border-radius: 10px;
    • background: rgba(0,0,0,0.1);
    • -webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0.5);
    • }
    • ::-webkit-scrollbar-thumb:window-inactive {
    • background: rgba(255,0,0,0.4);
    • }

    IE下面的CSS设置滚动条

    IE下面就比较简单那了,自定义的项目比较少,全是颜色。

    1. scrollbar-arrow-color: color; /*三角箭头的颜色*/
    2. scrollbar-face-color: color; /*立体滚动条的颜色(包括箭头部分的背景色)*/
    3. scrollbar-3dlight-color: color; /*立体滚动条亮边的颜色*/
    4. scrollbar-highlight-color: color; /*滚动条的高亮颜色(左阴影?)*/
    5. scrollbar-shadow-color: color; /*立体滚动条阴影的颜色*/
    6. scrollbar-darkshadow-color: color; /*立体滚动条外阴影的颜色*/
    7. scrollbar-track-color: color; /*立体滚动条背景颜色*/
    8. scrollbar-base-color:color; /*滚动条的基色*/

    浏览器滚动条插件

    最后吐槽下,作为三大浏览器的火狐暂时没有找到相关CSS。前些年,火狐很火,市场占有率一度威胁到IE的第一的位置。最近两年,火狐除了升级版本号,亮点很少;启动速度依旧很慢,内存占用居高不下,对CSS3和HTML5支持都走在各浏览器的后面。以前是因为火狐插件比较多,在插件数量和质量被chrome赶上来的情况下,没有理由在使用火狐了,果断转投chrome。

    最后自己的实例:

    #frame{height:550px;position:relative;320px;margin: 0 auto;padding-top:20px;overflow-y:auto;}
    #frame::-webkit-scrollbar{4px;background:#949494;-webkit-transition:all 0.3s ease-out;-moz-transition:all 0.3s ease-out;
    -o-transition:all 0.3s ease-out;transition:all 0.3s ease-out}
    #frame::-webkit-scrollbar-button{display:none}
    #frame::-webkit-scrollbar-track{background:#E6E6E6;}
    #frame::-webkit-scrollbar-thumb{background:#808080;border-radius:100px;-webkit-border-radius:100px}
    #frame::-webkit-scrollbar-thumb:active{background:#ccc}

  • 相关阅读:
    tomcat(5)-如何查看linux环境下的tomcat版本?
    【PAT甲级】1023 Have Fun with Numbers (20 分)
    Manthan, Codefest 19 (open for everyone, rated, Div. 1 + Div. 2)D(树状数组)
    【PAT甲级】1022 Digital Library (30 分)(模拟)
    Manthan, Codefest 19 (open for everyone, rated, Div. 1 + Div. 2)B(SET)
    Codeforces Round #551 (Div. 2)D(树形DP)
    Atcoder Grand Contest 037C(贪心,优先队列,思维)
    Codeforces Round #580 (Div. 2)D(思维,Floyd暴力最小环)
    Atcoder Grand Contest 037B(DP,组合数学,思维)
    Atcoder Grand Contest 037A(贪心,思维)
  • 原文地址:https://www.cnblogs.com/snowbaby-kang/p/3691930.html
Copyright © 2011-2022 走看看