css overflow属性及使用方法(场景)

20 篇文章 2 订阅

overflow这个属性还是挺实用的比如,一个div展示文字,想让超出部分隐藏就可以使用overflow:hidden,想让显示的画就用overflow:scroll;

1.overflow的属性

描述
visible默认值。内容不会被修剪,会呈现在元素框之外。
hidden内容会被修剪,并且其余内容是不可见的。
scroll内容会被修剪,但是浏览器会显示滚动条以便查看其余的内容。
auto如果内容被修剪,则浏览器会显示滚动条以便查看其余的内容。
inherit规定应该从父元素继承 overflow 属性的值。

 

浏览器支持

所有主流浏览器都支持 overflow 属性。

注释:任何的版本的 Internet Explorer (包括 IE8)都不支持属性值 "inherit"。

定义和用法

overflow 属性规定当内容溢出元素框时发生的事情。

说明

这个属性定义溢出元素内容区的内容会如何处理。如果值为 scroll,不论是否需要,用户代理都会提供一种滚动机制。因此,有可能即使元素框中可以放下所有内容也会出现滚动条。

默认值:visible
继承性:no
版本:CSS2
JavaScript 语法:object.style.overflow="scroll"

2.overflow使用及效果 

1.visible(默认值)

<html>
<head>
<style type="text/css">
div 
{
background-color:#00FFFF;
width:150px;
height:150px;
overflow:visible;
}
</style>
</head>

<body>
<p>如果元素中的内容超出了给定的宽度和高度属性,overflow 属性可以确定是否显示滚动条等行为。</p>

<div>
这个属性定义溢出元素内容区的内容会如何处理。如果值为 scroll,不论是否需要,用户代理都会提供一种滚动机制。因此,有可能即使元素框中可以放下所有内容也会出现滚动条。默认值是 visible。
</div>
</body>

</html>

 

 

visible就是不做任何修改(不过多解释)

2.hidden(超出部分被隐藏)

hidden就是设置了宽高,超出部分会被隐藏。

3. scroll(滚动)

scroll会给其容器加上一个滚动条(x,y都加上)。如果不想显示x轴可用下列方法控制。

verflow-x: hidden; 不显示横向的滚动条 

overflow-y: hidden; 不显示纵向的滚动条

overflow-x: scroll; 显示横向的滚动条

overflow-y: scroll; 显示纵向滚动条 

 3.auto(自动)

这个很长见一般都用这个(会根据文字长度自动来动态的来显示隐藏);

4.inherit

规定应该从父元素继承 overflow 属性的值。如果父元素有overflow属性就会继承父元素的overflow的属性。

3.修改滚动条样式

  • ::-webkit-scrollbar 滚动条整体部分
  • ::-webkit-scrollbar-thumb  滚动条里面的小方块,能向上向下移动(或往左往右移动,取决于是垂直滚动条还是水平滚动条)
  • ::-webkit-scrollbar-track  滚动条的轨道(里面装有Thumb)
  • ::-webkit-scrollbar-button 滚动条的轨道的两端按钮,允许通过点击微调小方块的位置。
  • ::-webkit-scrollbar-track-piece 内层轨道,滚动条中间部分(除去)
  • ::-webkit-scrollbar-corner 边角,即两个滚动条的交汇处
  • ::-webkit-resizer 两个滚动条的交汇处上用于通过拖动调整元素大小的小控件

具体设置滚动条样式可参考https://blog.csdn.net/cysear/article/details/70264148

点击这里去实践一下可看效果代码https://www.w3school.com.cn/tiy/t.asp?f=csse_overflow

  • 14
    点赞
  • 82
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: overflow:scroll 是一个CSS属性,用来设置一个元素在内容超出其容器尺寸时是否显示滚动条。在移动端中,overflow:scroll 有时可能失效的原因有以下几个: 1. 使用的元素不支持滚动:有些元素,比如 `<div>` 或 `<span>`,默认是不支持滚动的,只有设置了特定的CSS属性后才能实现滚动效果。因此,如果在一个不支持滚动的元素上使用 overflow:scroll,是不会有效果的。 2. 缺乏足够的内容:当容器内的内容没有超出容器的尺寸时,即使设置了 overflow:scroll,也不会显示滚动条。因此,检查一下容器内的内容是否足够多,以确保滚动条的显示。 3. 容器尺寸限制:有时,父容器对子容器的尺寸进行了限制,例如设置了固定的高度或宽度,并且没有提供足够的空间来显示滚动条。在这种情况下,即使设置了 overflow:scroll,滚动条依然不会显示。 解决这些问题的方法可能是: 1. 使用支持滚动的元素:如果需要实现滚动效果,可以考虑使用 `<ul>` 或 `<div>` 等支持滚动的元素,并在其上应用 overflow:scroll。 2. 提供足够的内容:确保容器内的内容超出容器的尺寸,以触发滚动条的显示。 3. 调整容器尺寸限制:如果父容器对子容器的尺寸进行了限制,可以尝试调整父容器的大小或使用其他布局方式,以确保滚动条可以正常显示。 除此之外,还有其他可能的原因导致 overflow:scroll 失效,如浏览器或设备的兼容性问题。在实际应用中,我们可以通过调试工具或其他开发者工具来进一步排查和解决该问题。 ### 回答2: overflow:scroll 在移动端失效的原因可能有以下几点: 1. 移动设备的触摸屏幕和滚动机制不同于传统的鼠标滚轮操作,因此浏览器默认禁用了 overflow:scroll 的功能。在移动设备上,用户可以通过手指滑动屏幕的方式来进行页面的滚动。 2. 移动设备的屏幕尺寸较小,因此浏览器在移动端对页面进行了优化,自动将 overflow:scroll 的内容进行了隐藏,并不会出现滚动条。这是为了保证页面在移动设备上可以正常显示,并减少页面占用的空间。 3. 在某些特定的移动浏览器中,可能存在一些兼容性问题,导致 overflow:scroll 失效。这可能是由于浏览器对 CSS 的支持程度不同或者存在一些 bug。 针对以上情况,我们可以通过以下方法来解决移动端下 overflow:scroll 失效的问题: 1. 使用移动端特有的滚动区域组件,例如提供了滚动功能的第三方组件(如 iScroll、better-scroll 等)来替代原生的 overflow:scroll。 2. 使用 CSS 属性 -webkit-overflow-scrolling: touch; 来启用移动设备的滚动效果。这个属性可以告诉浏览器在滚动区域内使用硬件加速的方式进行滚动,提升性能和流畅度。 3. 对于需要在移动端实现滚动效果的特定场景,可以考虑使用 position:fixed; 来固定页面的某个区域,并结合 touch 事件来实现自定义的滚动效果。 总结来说,overflow:scroll 在移动端失效主要是因为浏览器默认禁用了该功能或者移动设备的屏幕尺寸较小无法正常显示。我们可以借助特定的滚动组件或者 CSS 属性来实现移动端的滚动效果。 ### 回答3: overflow:scroll 是 CSS 属性,用于控制元素溢出内容时的滚动行为。在移动端中,有时会遇到 overflow:scroll 失效的情况。 造成 overflow:scroll 失效的可能原因有以下几种: 1. 元素没有定义固定的高度或宽度:在移动端,由于屏幕大小不一致,如果元素没有定义明确的高度或宽度,浏览器无法确定内容何时溢出,因此 overflow:scroll 属性可能无效。 解决方法:确保元素设置了固定的高度或宽度,如通过设置 height 或者 width 属性来约束元素的尺寸。这样浏览器就能根据内容是否溢出来决定是否显示滚动条。 2. 浏览器不支持滚动:在某些移动端浏览器中,特别是一些老旧的浏览器,可能不支持 overflow:scroll 属性。 解决方法:可以使用 Javascript 或者专门的滚动插件来实现滚动效果,或者尝试使用其他浏览器测试是否支持滚动属性。 3. 元素的位置固定或绝对定位:如果元素的定位方式为 fixed 或者 absolute,overflow:scroll 属性可能会失效。 解决方法:将元素的定位方式修改为 relative 或 static,或者在父级元素上设置 overflow 属性。 总结来说,在移动端中,如果遇到 overflow:scroll 失效的问题,需要确保元素定义了固定的高度或者宽度,浏览器支持滚动属性,以及元素的定位方式是否符合要求。如果仍然无法解决问题,可以尝试使用其他解决方案来实现滚动效果。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

崽崽的谷雨

漫漫前端路,摸爬滚打

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值