相信不少人都遇到过在设计中自定义滚动条样式的情景,以前我都是努力说服设计师接受浏览器自带的滚动条样式,可是这样只能规避仍是解决不了问题,最近在项目中遇到了,正好来总结一下。固然,兼容全部浏览器的滚动条样式目前是不存在的。css
IE下的滚动条样式
IE是最先提供滚动条的样式支持,嗯,好多年了,可是其它浏览器一直没有支持,IE独孤求败了。html
这些样式规则很简单:web
- scrollbar-arrow-color: color; /*三角箭头的颜色*/
- scrollbar-face-color: color; /*立体滚动条的颜色(包括箭头部分的背景色)*/
- scrollbar-3dlight-color: color; /*立体滚动条亮边的颜色*/
- scrollbar-highlight-color: color; /*滚动条的高亮颜色(左阴影?)*/
- scrollbar-shadow-color: color; /*立体滚动条阴影的颜色*/
- scrollbar-darkshadow-color: color; /*立体滚动条外阴影的颜色*/
- scrollbar-track-color: color; /*立体滚动条背景颜色*/
- scrollbar-base-color:color; /*滚动条的基色*/
大概就这些,你也能够定义cursor来定义滚动条的鼠标手势。浏览器
webkit的自定义滚动条样式
不过,webkit再也不是用简单的几个CSS属性,而是一坨的CSS伪元素:网站
- ::-webkit-scrollbar 滚动条总体部分
- ::-webkit-scrollbar-button 滚动条两端的按钮
- ::-webkit-scrollbar-track 外层轨道
- ::-webkit-scrollbar-track-piece 内层轨道,滚动条中间部分(除去)
- ::-webkit-scrollbar-thumb (拖动条?滑块?滚动条里面能够拖动的那个,肿么翻译好呢?)
- ::-webkit-scrollbar-corner 边角
- ::-webkit-resizer 定义右下角拖动块的样式
经过这些伪元素,能够彻底的重写一个网站的滚动条样式。spa
固然webkit提供的不止这些,还有不少伪类,能够更丰富滚动条样式:翻译
- :horizontal – horizontal伪类应用于水平方向的滚动条
- :vertical – vertical伪类应用于竖直方向的滚动条
- :decrement – decrement伪类应用于按钮和内层轨道(track piece)。它用来指示按钮或者内层轨道是否会减少视窗的位置(好比,垂直滚动条的上面,水平滚动条的左边。)
- :increment – increment伪类和decrement相似,用来指示按钮或内层轨道是否会增大视窗的位置(好比,垂直滚动条的下面和水平滚动条的右边。)
- :start – start伪类也应用于按钮和滑块。它用来定义对象是否放到滑块的前面。
- :end – 相似于start伪类,标识对象是否放到滑块的后面。
- :double-button – 该伪类以用于按钮和内层轨道。用于判断一个按钮是否是放在滚动条同一端的一对按钮中的一个。对于内层轨道来讲,它表示内层轨道是否紧靠一对按钮。
- :single-button – 相似于double-button伪类。对按钮来讲,它用于判断一个按钮是否本身独立的在滚动条的一段。对内层轨道来讲,它表示内层轨道是否紧靠一个single-button。
- :no-button – 用于内层轨道,表示内层轨道是否要滚动到滚动条的终端,好比,滚动条两端没有按钮的时候。
- :corner-present – 用于全部滚动条轨道,指示滚动条圆角是否显示。
- :window-inactive – 用于全部的滚动条轨道,指示应用滚动条的某个页面容器(元素)是否当前被激活。(在webkit最近的版本中,该伪类也能够用于::selection伪元素。webkit团队有计划扩展它并推进成为一个标准的伪类)
另外,:enabled、:disabled、:hover 和 :active 等伪类一样能够用于滚动条中。设计
关于具体的demo,这里再也不作了,网上已经有不少demo能够参考,好比,webkit官方的这个,具体的线上项目中也有现成的例子,好比,QQ空间的签到弹出框和豆瓣说的右侧详情栏(某条信息评论多的时候会显示)。3d
值得一提的是,webkit的这个伪类和伪元素的实现很强大,虽然类目有些多,可是咱们能够把滚动条当成一个页面元素来定义,也差很少能够用上一些高级的CSS3属性,好比渐变、圆角、RGBa等等,固然有些地方也能够用图片,而后图片也能够转换成Base64,总之,能够尽情发挥了。htm
参考文章:
http://trac.webkit.org/export/41842/trunk/LayoutTests/scrollbars/overflow-scrollbar-combinations.html