资讯专栏INFORMATION COLUMN

使用CSS实现无滚动条滚动

gself / 3468人阅读

摘要:滚动条一出现就破坏了效果。我们不希望出现滚动条,也不希望超出去的内容被放逐,就要保留鼠标滚动的效果。而内容设置然后再设置外层的小于内容的,就是用一个无滚动条的包裹另一个有滚动条的,从而实现隐藏滚动条的效果。

我们都知道,撸页面的时候当我们的内容超出了我们的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>测试数据1li>
48                 <li>测试数据2li>
49                 <li>测试数据3li>
50                 <li>测试数据4li>
51                 <li>测试数据5li>
52                 <li>测试数据6li>
53                 <li>测试数据7li>
54                 <li>测试数据8li>
55                 <li>测试数据9li>
56                 <li>测试数据10li>
57                 <li>测试数据11li>
58                 <li>测试数据12li>
59                 <li>测试数据13li>
60                 <li>测试数据14li>
61                 <li>测试数据15li>
62                 <li>测试数据16li>
63                 <li>测试数据17li>
64                 <li>测试数据18li>
65                 <li>测试数据19li>
66                 <li>测试数据20li>
67                 <li>测试数据21li>
68                 <li>测试数据22li>
69                 <li>测试数据23li>
70                 <li>测试数据24li>
71                 <li>测试数据25li>
72                 <li>测试数据26li>
73                 <li>测试数据27li>
74                 <li>测试数据28li>
75                 <li>测试数据29li>
76                 <li>测试数据30li>
77             ul>
78         div>
79     body>
80  
81 html>

感觉大家阅读到这里~~~

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/1832.html

相关文章

  • CSS世界》笔记四:流的保护与破坏

    摘要:和可以看作是同父异母的兄弟关系。例子如下结果如下而父元素设置属性的方式则是利用了的特性下面将会详细讲解结界全称为,中文为块级格式化上下文。 上一篇:《CSS世界》笔记三:内联元素与对齐下一篇:《CSS世界》笔记五:CSS层叠规则及元素隐藏 写在前面 原本博客名为浮动与定位,但是《CSS世界》第六章节的内容不仅有浮动定位,很大一部分篇幅都在讲BFC和overflow。更吸引人的是,作者将...

    he_xd 评论0 收藏0
  • 水平居中布局与滚动跳动的千年难题

    摘要:于是,问题来了,信息流页面,如新浪微博,是从上往下渲染的。,结构类似几个页面通过头部的水平导航刷新切换,结果有的页面有滚动条,有的没有。 绝大多数的页面间布局都是水平居中布局,主体定个宽度,然后margin: 0 auto的节奏~例如,妇女之友大淘宝的首页: .warp{ width:1190px; margin:0 auto; position:relativ...

    songjz 评论0 收藏0
  • 水平居中布局与滚动跳动的千年难题

    摘要:于是,问题来了,信息流页面,如新浪微博,是从上往下渲染的。,结构类似几个页面通过头部的水平导航刷新切换,结果有的页面有滚动条,有的没有。 绝大多数的页面间布局都是水平居中布局,主体定个宽度,然后margin: 0 auto的节奏~例如,妇女之友大淘宝的首页: .warp{ width:1190px; margin:0 auto; position:relativ...

    techstay 评论0 收藏0
  • 水平居中布局与滚动跳动的千年难题

    摘要:于是,问题来了,信息流页面,如新浪微博,是从上往下渲染的。,结构类似几个页面通过头部的水平导航刷新切换,结果有的页面有滚动条,有的没有。 绝大多数的页面间布局都是水平居中布局,主体定个宽度,然后margin: 0 auto的节奏~例如,妇女之友大淘宝的首页: .warp{ width:1190px; margin:0 auto; position:relativ...

    mo0n1andin 评论0 收藏0

发表评论

0条评论

gself

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<