使⽤CSS实现⽆滚动条滚动的两种⽅法
我们都知道,撸页⾯的时候当我们的内容超出了我们的div,往往会出现滚动条,影响美观。
尤其是当我们在做⼀些导航菜单的时候。滚动条⼀出现就破坏了UI效果。我们不希望出现滚动条,也不希望超出去的内容被放逐,就要保留⿏标滚动的效果。我们都知道overflow:hidden是可以隐藏滚动条的,但存在的问题是:页⾯或元素失去了滚动的特性,进⽽溢出内容也变得不可见,这样肯定是不可取的。百度下⼤部分都是在说overflow:hidden或者overflow-y: no可以解决问题,但是并不能很好的解决我们的问题,那么怎么办呢?
接下来⼩萌介绍⼏种简单的⽅法,但是也不是完美的解决问题了,各求所需吧
第⼀种:伪对象选择器
在webkit内核的浏览器⾥可以定义滚动条样式。在CSS初始处定义
::-webkit-scrollbar{
display:none;(或者是width: 0;)
}
不过⽬前本⽅法只在webkit内核浏览器中有效(Chrome,Safari)。
第⼆种:变相隐藏
⼤体思路是在div外⾯再套⼀个div。这个div设置overflow:hidden。⽽内容div设置 overflow-x: hidden;overflow-y: scroll;然后再设置外层div的width⼩于内容div的width,就是⽤⼀个⽆滚动条的div包裹另⼀个有滚动条的div,从⽽实现隐藏滚动条的效果。
例⼦:
<!DOCTYPE html>
<html>
<head>
<title>使⽤CSS实现⽆滚动条滚动</title>
<meta charset="UTF-8">
<style type="text/css">
body,html {
margin: 0;
padding: 0;
height: 100%;
overflow: hidden;
}
ul,li {
margin: 0;
padding: 0;
list-style: none;
}
.
box_wrap {
margin: 20px auto;
width: 200px;
height: 400px;
border: 1px solid #ccc;
overflow: hidden;
}
.box_wrap ul {
width: 220px;/* 多出20像素是滚动条的位置,会被⽗容器盖住就看不到了 */
height: 100%;
overflow-x: hidden;
overflow-y: auto;
}
.box_wrap ul li {
width: 200px;
height: 40px;
line-height: 40px;
border-bottom: 1px solid #ccc;
font-size: 12px;
text-align: center;
}
</style>
</head>
<body>
<div class="box_wrap">
<ul>
<li>测试数据1</li>
<li>测试数据2</li>
<li>测试数据3</li>
<li>测试数据4</li>
<li>测试数据5</li>
<li>测试数据6</li>
<li>测试数据7</li>
<li>测试数据8</li>
<li>测试数据9</li>
<li>测试数据10</li>
<li>测试数据11</li>
<li>测试数据12</li>
<li>测试数据13</li>
<li>测试数据14</li>
<li>测试数据15</li>
<li>测试数据16</li>
<li>测试数据17</li>
<li>测试数据18</li>
<li>测试数据19</li>
<li>测试数据20</li>css设置表格滚动条
<li>测试数据21</li>
<li>测试数据22</li>
<li>测试数据23</li>
<li>测试数据24</li>
<li>测试数据25</li>
<li>测试数据26</li>
<li>测试数据27</li>
<li>测试数据28</li>
<li>测试数据29</li>
<li>测试数据30</li>
</ul>
</div>
</body>
</html>
总结
以上所述是⼩编给⼤家介绍的使⽤CSS实现⽆滚动条滚动功能,希望对⼤家有所帮助,如果⼤家有任何疑问请给我留⾔,⼩编会及时回复⼤家的。在此也⾮常感谢⼤家对⽹站的⽀持!
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论