CSS3自定义滚动条样式

落日

原文地址:→传送门css

写在前面

滚动条是个很常见的东东,不过某些浏览器自带的滚动条确实不太好看啊,下面能够做为学习,探讨下自定义滚动条的实现,这样你的滚动条就能够美美的啦。可是,也只能玩玩,由于只针对webkit内核的浏览器啊啊啊啊啊!html

overflow介绍

定义:overflow 属性指定当它溢出其块级容器时,是否剪辑内容,渲染滚动条或显示内容。css3

属性值git

overflow:visible    //默认值。内容不会被修剪,超出内容会显示在元素框以外
overflow:hidden     //内容会被修剪。超出内容被隐藏
overflow:scroll     //内容会被修剪,浏览器会显示滚动条以便查看其他内容
overflow:auto       //若是内容被修剪,则浏览器会显示滚动条以便查看其他的内容。
overflow:inherit     //规定从该父元素继承overflow属性的值

注:任何的版本的 Internet Explorer (包括 IE8)都不支持属性值 "inherit"。github

当overflow设为除默认值(visible)之外的值时,将会建立一个会块级式化上下文(清除浮动的一种方式),更多可查看深刻理解BFC和Margin Collapseweb

小tipschrome

对于当行文本对超出部分的处理可以使用一下属性。(同时需设置元素的width值,还有overflow:hidden;white-space:nowrap;)浏览器

text-overflow:clip       //修剪文本。
text-overflow:ellipsis   //显示省略符号来表明被修剪的文本。
text-overflow:string     //使用给定的字符串来表明被修剪的文本。

对于多行文本则须要用到不规范属性-webkit-line-clamp,此处不细讲。点击此处参考学习

水平及垂直滚动条
使用overflow-xoverflow-y可分别设置水平及垂直方向上的滚动条。url

自定义滚动条实现

此部分针对webkit内核的浏览器,使用伪类来改变滚动条的默认样式,详情以下:
滚动条组成部分

1. ::-webkit-scrollbar                滚动条总体部分
2. ::-webkit-scrollbar-thumb          滚动条里面的小方块,能向上向下移动(或向左向右移动)
3. ::-webkit-scrollbar-track          滚动条的轨道(里面装有Thumb)
4. ::-webkit-scrollbar-button         滚动条的轨道的两端按钮,因为经过点击微调小方块的位置。
5. ::-webkit-scrollbar-track-piece    内层轨道,滚动条中间部分
6. ::-webkit-scrollbar-corner         边角,即垂直滚动条和水平滚动条相交的地方
7. ::-webkit-resizer                  两个滚动条的交汇处上用于拖动调整元素大小的小控件

滚动条组成结构图以下:
组成结构图

下面来一组简单自定义滚动条的实现:

<div class="box box7">
            <p>这个属性定义溢出元素内容区的内容会如何处理。若是值为 scroll,不管是否须要, 用户代理都会提供一种滚动机制。所以,有可能即便元素框中能够放下全部内容也 会出现滚动条。 这个属性定义溢出元素内容区的内容会如何处理。若是值为
                scroll,不管是否须要, 用户代理都会提供一种滚动机制。所以,有可能即便元素框中能够放下全部内容也 会出现滚动条。
            </p>
        </div>
        
    
        .box8::-webkit-scrollbar {
            width: 12px;
            background-color: #eee;
        }
        
        .box8::-webkit-scrollbar-track {
            background-color: #eee;
        }
        
        .box8::-webkit-scrollbar-thumb {
            background: #3DB6A4;
        }
        
        .box8::-webkit-scrollbar-button:start {
            background: url(./imgs/up.png) no-repeat;
            background-size: 12px 12px;
        }
        
        .box8::-webkit-scrollbar-button:end {
            background: url(./imgs/down.png) no-repeat;
            background-size: 12px 12px;
        }

更多效果以下图:
自定义滚动条

注意只在chrome下有效!!!!!!

源码地址

预览地址

小结

  • 没法兼容各大浏览器,只能在chrome下耍耍
  • 本文仅做参考,更多内容请看参考资料

参考资料

相关文章
相关标签/搜索