F2E_1CSS自定义滚动条样式


突然很看不惯默认的滚动条,于是研究了一番改成了现在的样子,兼容IE和基于webkit的浏览器,正好来总结一下。

一、IE下的滚动条样式 IE是最早提供滚动条的样式支持,嗯,好多年了,但是其它浏览器一直没有支持,IE独孤求败了。

这些样式规则很简单:

/*for IE*/
.test{
    scrollbar-base-color:color; /*滚动条的基色*/
    scrollbar-arrow-color: color; /*三角箭头的颜色*/
    scrollbar-track-color: #292929; /*立体滚动条背景颜色*/
    scrollbar-face-color: #4d4d4d;  /*立体滚动条的颜色(包括箭头部分的背景色)*/
    scrollbar-3dlight-color: #4d4d4d; /*立体滚动条上下的颜色*/
    scrollbar-highlight-color: #4d4d4d; /*滚动条的高亮颜色(左阴影)*/
    scrollbar-shadow-color: #4d4d4d; /*立体滚动条阴影的颜色*/
    scrollbar-darkshadow-color: #4d4d4d; /*立体滚动条外阴影的颜色*/
}

大概就这些,也可以定义cursor来定义滚动条的鼠标手势。缺点很明显,只能修改color属性并且得应用在<\ html class=”test” >, 效果用IE浏览器打开本页面即可看到。

二、webkit的自定义滚动条样式 当然,这里才是今天的重点。webkit不再是用简单的几个CSS属性,而是一坨的CSS伪元素:

::-webkit-scrollbar {  /*1 滚动条整体部分*/
    width: 10px;
    background: #cacaca url("http://bcs.duapp.com/codeshurrik-123/mooning.jpg?sign=MBO:C7bc76a3d7869d24b1c5964a25ffb5bb:s3S%2FFtWxGP9hf6DeUloXiHK57kA%3D");
    opacity: .8;	
    -webkit-transition: .25s;
}
::-webkit-scrollbar-button {	 /*2 滚动条两端的按钮*/
    width: 10px;
    height: 5px;
    -webkit-transition: .25s;
}
::-webkit-scrollbar-track {	 /*3 外层轨道(背景)*/
    background: #cacaca url("http://bcs.duapp.com/codeshurrik-123/mooning.jpg?sign=MBO:C7bc76a3d7869d24b1c5964a25ffb5bb:s3S%2FFtWxGP9hf6DeUloXiHK57kA%3D");
    /* border: thin solid lightgray; 
    box-shadow: 0px 0px 3px #dfdfdf inset; */
    border-radius: 10px;
    -webkit-transition: .25s;
}
:-webkit-scrollbar-track-piece{} /*4 内层轨道,滚动条中间部分(除去)*/
::-webkit-scrollbar-thumb {	 /*5 拖动条?滑块?滚动条里面可以拖动的那个,肿么翻译好呢?*/
    background: #969696;
    /* border: thin solid gray; */
    border-radius: 10px;
    -webkit-transition: .25s;
}
::-webkit-scrollbar-thumb:hover {
    background: #7d7d7d;
    -webkit-transition: .25s;
}
::-webkit-scrollbar-corner {} /*6 边角*/
::-webkit-resizer {} /*7 定义右下角拖动块的样式*/

通过这些伪元素,可以完全的重写一个网站的滚动条样式。

三、当然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 等伪类同样可以用于滚动条中。