zoukankan      html  css  js  c++  java
  • CSS3自定义滚动条样式 之 -webkit-scrollbar

    有没有觉得浏览器自带的原始滚动条很不美观,同时也有看到很多网站的自定义滚动条显得高端,就连chrome32.0开发板都抛弃了原始的滚动条,美观多了。那webkit浏览器是如何自定义滚动条的呢?

    前言

    webkit支持拥有overflow属性的区域,列表框,下拉菜单,textarea的滚动条自定义样式,所以用处还是挺大的。当然,兼容所有浏览器的滚动条样式目前是不存在的。

    演示

    来看看这2个滚动条demo: demo1(图片版)demo2(纯CSS3版)

    滚动条组成

    • ::-webkit-scrollbar 滚动条整体部分
    • ::-webkit-scrollbar-thumb  滚动条里面的小方块,能向上向下移动(或往左往右移动,取决于是垂直滚动条还是水平滚动条)
    • ::-webkit-scrollbar-track  滚动条的轨道(里面装有Thumb)
    • ::-webkit-scrollbar-button 滚动条的轨道的两端按钮,允许通过点击微调小方块的位置。
    • ::-webkit-scrollbar-track-piece 内层轨道,滚动条中间部分(除去)
    • ::-webkit-scrollbar-corner 边角,即两个滚动条的交汇处
    • ::-webkit-resizer 两个滚动条的交汇处上用于通过拖动调整元素大小的小控件

    简洁版

    这里就不贴出详细代码了,demo里面可以通过查看源码寻找具体样式的设置。来看看demo2中第二个滚动条的样式

    [css] view plain copy
     
    1. /*定义滚动条高宽及背景 高宽分别对应横竖滚动条的尺寸*/  
    2. ::-webkit-scrollbar  
    3. {  
    4.      16px;  
    5.     height: 16px;  
    6.     background-color: #F5F5F5;  
    7. }  
    8.   
    9. /*定义滚动条轨道 内阴影+圆角*/  
    10. ::-webkit-scrollbar-track  
    11. {  
    12.     -webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0.3);  
    13.     border-radius: 10px;  
    14.     background-color: #F5F5F5;  
    15. }  
    16.   
    17. /*定义滑块 内阴影+圆角*/  
    18. ::-webkit-scrollbar-thumb  
    19. {  
    20.     border-radius: 10px;  
    21.     -webkit-box-shadow: inset 0 0 6px rgba(0,0,0,.3);  
    22.     background-color: #555;  
    23. }  

    详细设置

    定义滚动条就是利用伪元素与伪类,那什么是伪元素和伪类呢?

    伪类大家应该很熟悉:link,:focus,:hover,此外CSS3中又增加了许多伪类选择器,如:nth-child,:last-child,:nth-last-of-type()等。

    CSS中的伪元素大家以前看过::first-line,:first-letter,:before,:after。那么在css3中,伪元素进行了调整,在以前的基础上增加了一个“:”也就是现在变成了“::first-letter,::first-line,::before,::after”,另外CSS3还增加了一个“::selection”。两个“::”和一个“:”在css3中主要用来区分伪类和伪元素。

    webkit的伪类和伪元素的实现很强,可以把滚动条当成一个页面元素来定义,再结合一些高级的CSS3属性,比如渐变、圆角、RGBa等等。然后如果有些地方要用图片,可以把图片也可以转换成Base64,不然每次都得加载那个多个图片,增加请求数。

    任何对象都可以设置:边框、阴影、背景图片等等,创建的滚动条任然会按照操作系统本身的设置来完成其交互的行为。下面的伪类可以应用到上面的伪元素中。有点小复杂,具体怎么写可以看第一个demo,那里也有注释。

    [css] view plain copy
     
    1. :horizontal  
    2. //horizontal伪类适用于任何水平方向上的滚动条  
    3.   
    4. :vertical  
    5. //vertical伪类适用于任何垂直方向的滚动条  
    6.   
    7. :decrement  
    8. //decrement伪类适用于按钮和轨道碎片。表示递减的按钮或轨道碎片,例如可以使区域向上或者向右移动的区域和按钮  
    9.   
    10. :increment  
    11. //increment伪类适用于按钮和轨道碎片。表示递增的按钮或轨道碎片,例如可以使区域向下或者向左移动的区域和按钮  
    12.   
    13. :start  
    14. //start伪类适用于按钮和轨道碎片。表示对象(按钮 轨道碎片)是否放在滑块的前面  
    15.   
    16. :end  
    17. //end伪类适用于按钮和轨道碎片。表示对象(按钮 轨道碎片)是否放在滑块的后面  
    18.   
    19. :double-button  
    20. //double-button伪类适用于按钮和轨道碎片。判断轨道结束的位置是否是一对按钮。也就是轨道碎片紧挨着一对在一起的按钮。  
    21.   
    22. :single-button  
    23. //single-button伪类适用于按钮和轨道碎片。判断轨道结束的位置是否是一个按钮。也就是轨道碎片紧挨着一个单独的按钮。  
    24.   
    25. :no-button  
    26. no-button伪类表示轨道结束的位置没有按钮。  
    27.   
    28. :corner-present  
    29. //corner-present伪类表示滚动条的角落是否存在。  
    30.   
    31. :window-inactive  
    32. //适用于所有滚动条,表示包含滚动条的区域,焦点不在该窗口的时候。  
    33.   
    34. ::-webkit-scrollbar-track-piece:start {  
    35. /*滚动条上半边或左半边*/  
    36. }  
    37.   
    38. ::-webkit-scrollbar-thumb:window-inactive {  
    39. /*当焦点不在当前区域滑块的状态*/  
    40. }  
    41.   
    42. ::-webkit-scrollbar-button:horizontal:decrement:hover {  
    43. /*当鼠标在水平滚动条下面的按钮上的状态*/  
    44. }  

    原文地址:http://www.xuanfengge.com/css3-webkit-scrollbar.html

  • 相关阅读:
    【模板】Sparse-Table
    UVa 11235 Frequent values
    【模板】树状数组
    UVa 1428 Ping pong
    数学技巧
    UVa 11300 Spreading the Wealth
    UVa 11729 Commando War
    UVa 11292 Dragon of Loowater
    POJ 3627 Bookshelf
    POJ 1056 IMMEDIATE DECODABILITY
  • 原文地址:https://www.cnblogs.com/cnblogs-jcy/p/7327376.html
Copyright © 2011-2022 走看看