使用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实现无滚动条滚动</ 6  
 7         meta charset="UTF-8" 8         style type="text/css" 9             body,html {
10                 margin: 0;
11                 padding12                 height 100%13                 overflow hidden14             }
15             ul,li 16 17 18                 list-style none19             20             .box_wrap 21  20px auto22                 width 200px23  400px24                 border 1px solid #ccc25 26             27             .box_wrap ul  28  220px;/* 多出20像素是滚动条的位置,会被父容器盖住就看不到了 */
29 30                 overflow-x31                 overflow-y auto32             33             .box_wrap ul li 34 35  40px36                 line-height37                 border-bottom38                 font-size 12px39                 text-align center40             41         style42     43  
44     body45         div class="box_wrap"46             ul47                 li>测试数据148                 >测试数据249                 >测试数据350                 >测试数据451                 >测试数据552                 >测试数据653                 >测试数据754                 >测试数据855                 >测试数据956                 >测试数据1057                 >测试数据1158                 >测试数据1259                 >测试数据1360                 >测试数据1461                 >测试数据1562                 >测试数据1663                 >测试数据1764                 >测试数据1865                 >测试数据1966                 >测试数据2067                 >测试数据2168                 >测试数据2269                 >测试数据2370                 >测试数据2471                 >测试数据2572                 >测试数据2673                 >测试数据2774                 >测试数据2875                 >测试数据2976                 >测试数据3077             78         div79     80  
81 >

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

相关文章

Css常用的排序方式权重分配 排序方式: 1、按类型&#160;...
原文:https://www.cnblogs.com/wenruo/p/9732704.html 先上...
css属性:word-wrap:break-word; 与 word-break:break-all 的...
https://destiny001.gitee.io/color/
&lt;!DOCTYPE html PUBLIC &quot;-//W3C//DTD XHTML...
css之background的cover和contain的缩放背景图 对于这两个属...