因为在现在的大部分项目中很多都用到了滚动条,有时候用到模拟的滚动条,现在说下滚动条的 CSS 也能解决。
比如网易邮箱的滚动条样子很好看,就是利用的 CSS 来设置的,而且是 webkit 浏览器的。如图所示:
下面就讲解这几个属性怎么使用,代表什么意思。
一:webkit 下面的 CSS 设置滚动条
主要有下面 7 个属性
::-webkit-scrollbar 滚动条整体部分,可以设置宽度啥的
::-webkit-scrollbar-button 滚动条两端的按钮
::-webkit-scrollbar-track 外层轨道
::-webkit-scrollbar-track-piece 内层滚动槽
::-webkit-scrollbar-thumb 滚动的滑块
::-webkit-scrollbar-corner 边角
::-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 团队有计划扩展它并推动成为一个标准的伪类)
CSS 也很简单,例:
/* 设置滚动条的样式 */
::-webkit-scrollbar {width:12px;}
/* 滚动槽 */
::-webkit-scrollbar-track {-webkit-box-shadow:inset006pxrgba(0,0,0,0.3);
border-radius:10px;
}
/* 滚动条滑块 */
::-webkit-scrollbar-thumb {
border-radius:10px;
background:rgba(0,0,0,0.1);
-webkit-box-shadow:inset006pxrgba(0,0,0,0.5);
}
::-webkit-scrollbar-thumb:window-inactive {background:rgba(255,0,0,0.4);
}
二:IE 下面的 CSS 设置滚动条
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; / 滚动条的基色/
如果您觉得本文对您的学习有所帮助,请多支持与鼓励。