阅读 2490

自定义浏览器滚动条样式

昨天看微信小程序开发文档的时候,发现网页的滚动条并不是系统默认的样式,配个图体会下

chrome 浏览器下显示(safari 下亦如此)

firefox 浏览器下显示
ie 浏览器下显示
看下源码发现只是 webkit内核的浏览器才生效,也就是没给 firefox 和 ie 做兼容(好任性)

以前没怎么修改过滚动条样式,顶多是让滚动条隐藏。既然遇到了,就简单的查一下,捋一捋。不查不知道,一查才发现网上有些还介绍挺全的,那我写这篇文章的意义何在?……算了,本着不浪费...我截的这几张图的原则...自己动手试一下呗,也算做个记录。

webkit内核浏览器下修改样式

其实,代码很简单,css部分:

* {
    margin: 0;
    padding: 0;
}
div {
    width: 300px;
    height: 150px;
    border: 1px solid #444;
    margin: 50px;
    overflow: auto;
}
p {
    width: 400px;
}
    
/*控制整个滚动条*/
::-webkit-scrollbar {
    background-color: lightgray;
    width: 10px;
    height: 10px;
    background-clip: padding-box;
}

/*滚动条两端方向按钮*/
::-webkit-scrollbar-button {
    background-color: pink;
}

/*滚动条中间滑动部分*/
::-webkit-scrollbar-thumb {
    background-color: blue;
    border-radius: 5px;
}

/*滚动条右下角区域*/
::-webkit-scrollbar-corner {
    background-color: red;
}
复制代码

html结构部分

<div>
    <p>Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-Webkit内核浏览器滚动条测试-</p>
</div>
复制代码

chrome 下效果如下(样式比较low,凑合看):

ie浏览器修改样式

div {
   scrollbar-arrow-color: #f4ae21; /**//*三角箭头的颜色*/   
   scrollbar-face-color: #333; /**//*立体滚动条的颜色*/   
   scrollbar-3dlight-color: #666; /**//*立体滚动条亮边的颜色*/   
   scrollbar-highlight-color: #666; /**//*滚动条空白部分的颜色*/   
   scrollbar-shadow-color: #999; /**//*立体滚动条阴影的颜色*/   
   scrollbar-darkshadow-color: #666; /**//*立体滚动条强阴影的颜色*/   
   scrollbar-track-color: #666; /**//*立体滚动条背景颜色*/   
   scrollbar-base-color:#f8f8f8; /**//*滚动条的基本颜色*/ 
}
复制代码

效果如下

感觉 ie 能修改的样式还是少了,比如宽高应该是不能设置(也可能我没找到)。另外 firefox 下样式暂时没有找到好的解决方法,网上找到的试过都没有生效,如果有找到的可以告知下,感谢。

放下参考传送门,感谢,侵必删 传送门1 传送门2

其实感觉这篇文章水分有点大,有些东西都不是自己原创的,继续努力吧

关注下面的标签,发现更多相似文章
评论