css设置滚动条样式

断了今生、忘了曾经 提交于 2019-11-27 06:30:33

        近期在做一个项目,由于主题风格是黑色的,而浏览器默认的滚动条的风格放到页面上颜色太突兀,就想着该给它修改一下样式,以下是我整理的通过css设置滚动条样式。

        查了很多资料,由于各个浏览器都有各自不同的滚动条设置方法,有些甚至不支持修改样式,这里就三大浏览器Chrome、IE、firefox说一下他们的样式设置。

1、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设置的一个例子:

/* 设置Chrome浏览器下滚动条的样式 */
::-webkit-scrollbar {/*滚动条*/
    width:12px;
}
::-webkit-scrollbar-track {/*滚动槽*/
    -webkit-box-shadow:inset 0 0 6px rgba(0,0,0,0.3);
    border-radius:10px;
}
::-webkit-scrollbar-thumb {/*滚动条滑块*/
    border-radius:10px;
    background:rgba(0,0,0,0.1);
    -webkit-box-shadow:inset 0 0 6px rgba(0,0,0,0.5);
}

        预览效果如下(Chrome浏览器)

        注意:这个例子我只用了其中三个属性,其他属性缺省默认是无,在这里我认为这三个属性就已经足够美观了,其他属性请读者自行调试预览效果。

2、IE下面的cs设置滚动条

        IE下面就比较简单,全是颜色的设置,相对于Chrome的灵活性较小。

  • 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;  /*滚动条的基色*/

        还是用图来理解滚动条样式的控制:

        下面是css设置的一个例子:

.test-scrollbar {
    /*IE浏览器下滚动条样式颜色*/
    scrollbar-base-color: #C4E36F;/*滚动条的基色*/
    scrollbar-track-color: #C4E36F;/*立体滚动条背景颜色*/
    scrollbar-face-color: #A2DE43;/*立体滚动条的颜色(包括箭头部分的背景色)*/
    scrollbar-darkshadow-color: #A2DE43;/*立体滚动条外阴影的颜色*/
    scrollbar-shadow-color: #A2DE43;/*立体滚动条阴影的颜色*/
    scrollbar-arrow-color: #74D32E; /*三角箭头的颜色*/
}
        预览效果如下(IE浏览器):



三、firefox下面的css设置滚动条

        哈哈,因为firefox浏览器真的不太容易修改滚动条样式,所以没有试出来 >:< 

四、设置各个浏览器统一样式的滚动条

        这个需要用到一些插件,通过css无法统一各个浏览器的样式



易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!