我们都知道,撸页面的时候当我们的内容超出了我们的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 >
感觉大家阅读到这里~~~