CSS⾃定义滚动条样式标准写法
相信很多⼈都遇到过在设计中⾃定义滚动条样式的情景,之前我都是努⼒说服设计师接受浏览器⾃带的滚动条样式,但是这样只能规避还是解决不了问题,最近在项⽬中遇到了,正好来总结⼀下。当然,兼容所有浏览器的滚动条样式⽬前是不存在的。
IE下的滚动条样式
IE是最早提供滚动条的样式⽀持,嗯,好多年了,但是其它浏览器⼀直没有⽀持,IE独孤求败了。
这些样式规则很简单:
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来定义滚动条的⿏标⼿势。
这⾥,很久以前做了个,简单但是好⽤:
选中CSS选项即可⾃动⽣成CSS样式,这⾥不再过多的介绍了。嗯,多谢⽼师推荐。
webkit的⾃定义滚动条样式
yes,这⾥才是今天要重点介绍的。
从上⼀部分的样式名中就可以看到,IE只能定义相关部分的color等属性,这样太不灵活了。
webkit最近实现了对滚动条的⽀持,先看⼀个简单的demo:
不过,webkit不再是⽤简单的⼏个CSS属性,⽽是⼀坨的CSS伪元素:
:
:-webkit-scrollbar 滚动条整体部分
::-webkit-scrollbar-button 滚动条两端的按钮css设置表格滚动条
::-webkit-scrollbar-track 外层轨道
::-webkit-scrollbar-track-piece 内层轨道,滚动条中间部分(除去)
::-webkit-scrollbar-thumb (拖动条?滑块?滚动条⾥⾯可以拖动的那个,肿么翻译好呢?)
::-webkit-scrollbar-corner 边⾓
::-webkit-resizer 定义右下⾓拖动块的样式
通过这些伪元素,可以完全的重写⼀个⽹站的滚动条样式。
当然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可以参考,⽐如,具体的线上项⽬中也有现成的例⼦,⽐如,QQ空间的签到弹出框和⾖瓣说的右侧详情栏(某条信息评论多的时候会显⽰)。
值得⼀提的是,webkit的这个伪类和伪元素的实现很强⼤,虽然类⽬有些多,但是我们可以把滚动条当成⼀个页⾯元素来定义,也差不多可
以⽤上⼀些⾼级的CSS3属性,⽐如渐变、圆⾓、RGBa等等,当然有些地⽅也可以⽤图⽚,然后图⽚也可以转换成Base64,总之,可以尽情发挥了。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。