CSS---前端通过 css如何实现overflow:auto滚动超出部分的同时隐藏滚动条?

动端页面为了更接近原生的体验,是否可以隐藏滚动条,同时又保证页面可以滚动?

使用 overflow:hidden 隐藏滚动条,但存在的问题是:页面或元素失去了滚动的特性。
由于只需要兼容移动浏览器(Chrome 和 Safari),于是想到了自定义滚动条的伪对象选择器

::-webkit-scrollbar

应用如下 CSS 可以隐藏滚动条:

.element::-webkit-scrollbar {display:none}

如果要兼容 PC 其他浏览器(IE、Firefox 等),国外一位才人 John Kurlak 也研究出了一种办法。在容器外面再嵌套一层 overflow:hidden 内部内容再限制尺寸和外部嵌套层一样,就变相隐藏了。

<div class="outer-container">
     <div class="inner-container">
        <div class="content">
            ......
        </div>
     </div>
 </div>
.outer-container,.content {
    width: 200px; height: 200px;
}
.outer-container {
    position: relative;
    overflow: hidden;
}
.inner-container {
    position: absolute; left: 0;
    overflow-x: hidden;
    overflow-y: scroll;
}

 /* for Chrome */
.inner-container::-webkit-scrollbar {
    display: none;
}

转载

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 的方法是什么? 在 CSS 中,可以使用 "overflow: hidden" 来隐藏滚动条。这样,如果内容超出了容器的大小,将不会显示滚动条。 例如: ``` div { overflow: hidden; } ``` ### 回答2: 使用overflow:auto属性可以隐藏滚动条。当使用overflow:auto属性时,如果内容超出了容器的大小,滚动条会自动出现。这个属性会在需要时自动添加滚动条,而在内容不超出容器大小时则不显示滚动条。 当设置overflow:auto时,如果内容超出了容器的大小,会在水平和垂直方向上都出现滚动条。这样用户就可以通过滚动条来查看超出部分的内容。当内容没有超出容器大小时,没有滚动条显示。 使用overflow:auto属性隐藏滚动条可以让页面更加美观和整洁。而不使用该属性,当内容超出容器大小时会出现滚动条,可能会破坏页面的布局,并降低用户体验。 除了overflow:auto,还有其他属性可以隐藏滚动条,比如overflow:hidden。但使用overflow:hidden时,超出容器大小的内容将被隐藏,用户无法通过滚动条来查看。因此,在需要滚动的情况下,一般推荐使用overflow:auto隐藏滚动条。 ### 回答3: 当使用`overflow:auto`来隐藏滚动条时,页面内容将被包含在一个容器元素中。该元素的大小和位置将根据内容的大小自动调整。在这种情况下,如果内容超过容器的大小,容器将显示滚动条,以便用户可以滚动查看内容的其他部分。 相比于使用其他方法来隐藏滚动条,`overflow:auto`的优势在于它只会在内容超过容器大小时展示滚动条。这意味着当内容不足以填满容器时,滚动条将自动隐藏,使页面更美观。 在页面中使用`overflow:auto`的一个常见应用是在含有长内容的区域中,如文章、评论或电子邮件列表。这样,当内容过多以致无法一次显示完整时,用户可以通过滚动条来查看隐藏的内容。 但需要注意的是,`overflow:auto`只能隐藏页面内容区域的滚动条,而无法隐藏浏览器本身的滚动条。如果想要隐藏整个页面的滚动条,可以使用其他方法,如通过调整页面布局或使用JavaScript来实现

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值