使用CSS实现无滚动条滚动
程序员文章站
2022-06-18 15:53:50
我们都知道,撸页面的时候当我们的内容超出了我们的div,往往会出现滚动条,影响美观。 尤其是当我们在做一些导航菜单的时候。滚动条一出现就破坏了UI效果。 我们不希望出现滚动条,也不希望超出去的内容被放逐,就要保留鼠标滚动的效果。我们都知道overflow:hidden是可以隐藏滚动条的,但存在的问题 ......
我们都知道,撸页面的时候当我们的内容超出了我们的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>
感觉大家阅读到这里~~~