使用CSS实现无滚动条滚动
程序员文章站
2022-04-18 18:36:45
...
我们都知道,撸页面的时候当我们的内容超出了我们的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>
感觉大家阅读到这里~~~
本文转载于:猿2048https://www.mk2048.com/blog/blog.php?id=1ikkcb&title=使用CSS实现无滚动条滚动
上一篇: android基于socket的局域网内服务器与客户端加密通信
下一篇: JVM 堆溢出 栈溢出