纯CSS3 自定义滚动条样式设置方法大全(不兼容firefox)

老白 2周前 21浏览 0评论

 纯CSS3 自定义滚动条样式设置方法大全(不兼容firefox) CSS学习 第1张

刚写过一篇使用jQuery滚动条插件jQuery custom content scroller,兼容所有浏览器,但缺点也非常明显,就是过大了,高达100K左右的JS+css,非常不友好。

本文分享的是纯CSS方法,但缺点也明显,不兼容firefox,看过很多兼容firefox的方法,但因为firefox的更新很多都失效了,以后遇到再重点写下firefox的滚动条样式。

/*滚动条*/
.widget_kuaixun ul::scrollbar{width: 0.2rem;background-color: transparent;}
/*定义滚动条的轨道,内阴影及圆角*/
.widget_kuaixun ul::scrollbar-track{-webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0);border-radius: 0.2rem;background-color: transparent;}
/*定义滑块,内阴影及圆角*/
.widget_kuaixun ul::scrollbar-thumb{border-radius: 0.2rem;-webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0);background-color: rgba(0,0,0,0); /*未触发*/}
/*触发后显示内滚动条*/
.widget_kuaixun ul:hover::scrollbar-thumb{background-color: rgba(0,0,0,.3);}
.widget_kuaixun ul::-webkit-scrollbar{width: 0.2rem;background-color: transparent;}
/*定义滚动条的轨道,内阴影及圆角*/
.widget_kuaixun ul::-webkit-scrollbar-track{-webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0);border-radius: 0.2rem;background-color: transparent;}
/*定义滑块,内阴影及圆角*/
.widget_kuaixun ul::-webkit-scrollbar-thumb{border-radius: 0.2rem;-webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0);background-color: rgba(0,0,0,0); /*未触发*/}
/*触发后显示内滚动条*/
.widget_kuaixun ul:hover::-webkit-scrollbar-thumb{background-color: rgba(0,0,0,.3);}
.widget_kuaixun ul::-o-scrollbar{width: 0.2rem;background-color: transparent;}
/*定义滚动条的轨道,内阴影及圆角*/
.widget_kuaixun ul::-moz-scrollbar-track{-webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0);border-radius: 0.2rem;background-color: transparent;}
/*定义滑块,内阴影及圆角*/
.widget_kuaixun ul::-moz-scrollbar-thumb{border-radius: 0.2rem;-webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0);background-color: rgba(0,0,0,0); /*未触发*/}
/*触发后显示内滚动条*/
.widget_kuaixun ul:hover::-moz-scrollbar-thumb{background-color: rgba(0,0,0,.3);}

CSS3自定义滚动条样式 -webkit-scrollbar

有时候觉得浏览器自带的原始滚动条不是很美观,那webkit浏览器是如何自定义滚动条的呢?

Webkit支持拥有overflow属性的区域,列表框,下拉菜单textarea的滚动条自定义样式。当然,兼容所有浏览器的滚动条样式目前是不存在的。

滚动条的组成:

 ::-webkit-scrollbar         滚动条整体部分
 ::-webkit-scrollbar-thumb             滚动条里面的小方块,能上下左右移动(取决于是垂直滚动条还是水平滚动条)
 ::-webkit-scrollbar-track      滚动条的轨道(里面装有thumb)
 ::-webkit-scrollbar-button      滚动条轨道两端的按钮,允许通过点击微调小方块的位置
 ::-webkit-scrollbar-track-piece    内层轨道,滚动条中间部分(除去)
 ::-webkit-scrollbar-corner     边角,及两个滚动条的交汇处
 ::-webkit-resizer       两个滚动条的交汇处上用于通过拖动调整元素大小的小控件

自定义滚动条简单版:

/*定义滚动条宽高及背景,宽高分别对应横竖滚动条的尺寸*/

.scrollbar::-webkit-scrollbar{

    width: 16px;

    height: 16px;

    background-color: #f5f5f5;

}

/*定义滚动条的轨道,内阴影及圆角*/

.scrollbar::-webkit-scrollbar-track{

    -webkit-box-shadow: inset 0 0 6px rgba(0,0,0,.3);

    border-radius: 10px;

    background-color: #f5f5f5;

}

/*定义滑块,内阴影及圆角*/

.scrollbar::-webkit-scrollbar-thumb{

    /*width: 10px;*/

    height: 20px;

    border-radius: 10px;

    -webkit-box-shadow: inset 0 0 6px rgba(0,0,0,.3);

    background-color: #555;

}

自定义滚动条效果图:

纯CSS3 自定义滚动条样式设置方法大全(不兼容firefox) CSS学习 第2张


  1. webkit浏览器css设置滚动条:(下面是他的7个主要的属性)

    1. ::-webkit-scrollbar 滚动条整体部分,可以设置宽度啥的

    2. ::-webkit-scrollbar-button 滚动条两端的按钮(滚动条轨道两端的按钮,允许通过点击微调小方块的位置)

    3. ::-webkit-scrollbar-track  外层轨道(滚动条的轨道,里面装有thumb)

    4. ::-webkit-scrollbar-track-piece  内层滚动槽

    5. ::-webkit-scrollbar-thumb 滚动的滑块

    6. ::-webkit-scrollbar-corner 边角

    7. ::-webkit-resizer 定义右下角拖动块的样式

    8. 以下是webkit浏览器css设置滚动条的其他属性:

    9.  

      :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团队有计划扩展它并推动成为一个标准的伪类)

    10.  

       

IE下面的CSS设置滚动条(IE比较简单,自定义的项目比较少,全是颜色。)

 

  • scrollbar-arrow-color: color; /*三角箭头的颜色*/

    1. scrollbar-face-color: color; /*立体滚动条的颜色(包括箭头部分的背景色)*/

    2. scrollbar-3dlight-color: color; /*立体滚动条亮边的颜色*/

    3. scrollbar-highlight-color: color; /*滚动条的高亮颜色(左阴影?)*/

    4. scrollbar-shadow-color: color; /*立体滚动条阴影的颜色*/

    5. scrollbar-darkshadow-color: color; /*立体滚动条外阴影的颜色*/

    6. scrollbar-track-color: color; /*立体滚动条背景颜色*/

    7. scrollbar-base-color:color; /*滚动条的基色*/

下面是以webkit为例子写的:
  1.  

    .index .financial::-webkit-scrollbar{    width: 0.2rem;    background-color: #f5f5f5;}/*定义滚动条的轨道,内阴影及圆角*/.index .financial::-webkit-scrollbar-track{    -webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0.3);    border-radius: 0.2rem;    background-color: #f5f5f5;}/*定义滑块,内阴影及圆角*/.index .financial::-webkit-scrollbar-thumb{    border-radius: 0.2rem;    -webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0.3);    background-color: red;}

    最后如下图:

  2. 纯CSS3 自定义滚动条样式设置方法大全(不兼容firefox) CSS学习 第3张

  3. 当然这个只是测试的,剩下的,就根据UI的来改对应的属性就可以了。

 

发表评论