zoukankan      html  css  js  c++  java
  • 使用CSS实现无滚动条滚动

    我们都知道,撸页面的时候当我们的内容超出了我们的div,往往会出现滚动条,影响美观。

    尤其是当我们在做一些导航菜单的时候。滚动条一出现就破坏了UI效果。 我们不希望出现滚动条,也不希望超出去的内容被放逐,就要保留鼠标滚动的效果。我们都知道overflow:hidden是可以隐藏滚动条的,但存在的问题是:页面或元素失去了滚动的特性,进而溢出内容也变得不可见,这样肯定是不可取的。百度下大部分都是在说overflow:hidden或者overflow-y: no可以解决问题,但是并不能很好的解决我们的问题,那么怎么办呢?

    接下来小萌介绍几种简单的方法,但是也不是完美的解决问题了,各求所需吧

    第一种:伪对象选择器

    在webkit内核的浏览器里可以定义滚动条样式。在CSS初始处定义

    1 ::-webkit-scrollbar{
    2 display:none;(或者是width: 0;)
    3 }

    不过目前本方法只在webkit内核浏览器中有效(Chrome,Safari)。

    第二种:变相隐藏

    大体思路是在div外面再套一个div。这个div设置overflow:hidden。而内容div设置 overflow-x: hidden;overflow-y: scroll;然后再设置外层div的width小于内容div的width,就是用一个无滚动条的div包裹另一个有滚动条的div,从而实现隐藏滚动条的效果。
    例子:

     1 <!DOCTYPE html>
     2 <html>
     3  
     4     <head>
     5         <title>使用CSS实现无滚动条滚动</title>
     6  
     7         <meta charset="UTF-8">
     8         <style type="text/css">
     9             body,html {
    10                 margin: 0;
    11                 padding: 0;
    12                 height: 100%;
    13                 overflow: hidden;
    14             }
    15             ul,li {
    16                 margin: 0;
    17                 padding: 0;
    18                 list-style: none;
    19             }
    20             .box_wrap {
    21                 margin: 20px auto;
    22                 width: 200px;
    23                 height: 400px;
    24                 border: 1px solid #ccc;
    25                 overflow: hidden;
    26             }
    27             .box_wrap ul  {
    28                 width: 220px;/* 多出20像素是滚动条的位置,会被父容器盖住就看不到了 */
    29                 height: 100%;
    30                 overflow-x: hidden;
    31                 overflow-y: auto;
    32             }
    33             .box_wrap ul li {
    34                 width: 200px;
    35                 height: 40px;
    36                 line-height: 40px;
    37                 border-bottom: 1px solid #ccc;
    38                 font-size: 12px;
    39                 text-align: center;
    40             }
    41         </style>
    42     </head>
    43  
    44     <body>
    45         <div class="box_wrap">
    46             <ul>
    47                 <li>测试数据1</li>
    48                 <li>测试数据2</li>
    49                 <li>测试数据3</li>
    50                 <li>测试数据4</li>
    51                 <li>测试数据5</li>
    52                 <li>测试数据6</li>
    53                 <li>测试数据7</li>
    54                 <li>测试数据8</li>
    55                 <li>测试数据9</li>
    56                 <li>测试数据10</li>
    57                 <li>测试数据11</li>
    58                 <li>测试数据12</li>
    59                 <li>测试数据13</li>
    60                 <li>测试数据14</li>
    61                 <li>测试数据15</li>
    62                 <li>测试数据16</li>
    63                 <li>测试数据17</li>
    64                 <li>测试数据18</li>
    65                 <li>测试数据19</li>
    66                 <li>测试数据20</li>
    67                 <li>测试数据21</li>
    68                 <li>测试数据22</li>
    69                 <li>测试数据23</li>
    70                 <li>测试数据24</li>
    71                 <li>测试数据25</li>
    72                 <li>测试数据26</li>
    73                 <li>测试数据27</li>
    74                 <li>测试数据28</li>
    75                 <li>测试数据29</li>
    76                 <li>测试数据30</li>
    77             </ul>
    78         </div>
    79     </body>
    80  
    81 </html>

    感觉大家阅读到这里~~~

  • 相关阅读:
    C#编程思路
    将字符串类型字段转为map类型字段,使用str_to_map()函数
    写hive脚本时,如果hive的过滤条件比较多。可以把过滤条件放到一个参数里。然后把参数放到过滤条件处。这样以后只需要改参数就可以了
    linux中. 路径/文件
    inner join ,left join 会导致数据发散
    如何批量按分区插入数据
    hive表添加字段后,查不出数据是咋回事?
    linux中$0的含义
    linux中的$#含义
    linux的语法
  • 原文地址:https://www.cnblogs.com/zmdComeOn/p/9618085.html
Copyright © 2011-2022 走看看