网页制作 
首页 > 网页制作 > 浏览文章

使用CSS实现无滚动条滚动的两种方法

(编辑:jimmy 日期: 2024/11/28 浏览:3 次 )

我们都知道,撸页面的时候当我们的内容超出了我们的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>
                <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实现无滚动条滚动功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!

上一篇:利用CSS3动画实现圆圈由小变大向外扩散的效果实例
下一篇:纯CSS实现微信小程序仿QQ顶部提示弹框动画效果
一句话新闻
高通与谷歌联手!首款骁龙PC优化Chrome浏览器发布
高通和谷歌日前宣布,推出首次面向搭载骁龙的Windows PC的优化版Chrome浏览器。
在对骁龙X Elite参考设计的初步测试中,全新的Chrome浏览器在Speedometer 2.1基准测试中实现了显著的性能提升。
预计在2024年年中之前,搭载骁龙X Elite计算平台的PC将面世。该浏览器的提前问世,有助于骁龙PC问世就获得满血表现。
谷歌高级副总裁Hiroshi Lockheimer表示,此次与高通的合作将有助于确保Chrome用户在当前ARM兼容的PC上获得最佳的浏览体验。
友情链接:杰晶网络 DDR爱好者之家 南强小屋 黑松山资源网 白云城资源网 网站地图 SiteMap