CSS 溢出overflow属性的使用

简介: CSS overflow属性

作者:WangMin
格言:努力做好自己喜欢的每一件事

在CSS中,如果给一个盒子设置了固定的宽度与高度,但内容过多就会溢出盒子本身的宽度或高度。此时,就可以使用 overflow 属性来控制内容溢出时的处理方式。那么接下来就开始来学习这个属性吧!

1.png

overflow 属性值如下:

属性值 含义
visible 不剪切形式也不添加转动条,也就是元素的内容在元素框之外也可见
auto 如果内容被剪裁,则浏览器会显示滚动条以便查看其余的内容
hidden 元素的内容会在元素框的边界处剪裁,并且超出元素框之外的内容不可见
scroll  元素的内容会在元素框的边界处剪裁,但浏览器会显示滚动条以便查看其余的内容

overflow 属性的延伸:overflow-X | overflow-y

属性 含义
overflow-x 主要用来定义对水平方向内容溢出的剪切
overflow-y 主要用来定义对垂直方向内容溢出的剪切

[注意]:如果 overflow-x 和 overflow-y 值相同则等同于overflow;如果overflow-x和overflow-y值不同,其中一个值显式设置为visible或未设置默认为visible,而另外一个值是非visible(除默认值以外的其他值)的值,则visible值会被重置为auto。

overflow:visible

如果没有给元素设置 overflow属性,表示使用其默认值 visible,让溢出的内容可见。此时,溢出的内容就会渲染到盒子的外面。例如,有一个盒子设置了固定宽度和高度,其中它的内容的尺寸超过了盒子本身的尺寸,效果如下:

<div class="box">
        <p>
            在CSS中,如果给一个盒子设置了固定的宽度与高度,但内容过多就会溢出盒子本身的宽度或高度。
            此时,就可以使用 overflow 属性来控制内容溢出时的处理方式。那么接下来就开始来学习这个属性吧!
        </p>
</div>
.box{
   
   
    width:150px;
    height:150px;
    overflow:visible;
    background:pink;
    color:#666;
}

2.png

[注意]:
1、溢出的内容不会改变盒子的形状,盒子外面的内容是可见的,但它不会把周围其他容器挤下去。所以,溢出的内容不会影响页面布局,但溢出的内容可能与周围其他容器重叠。

2、就上面的例子来说,在IE6和更低版本中,超出的内容会撑开盒子的高度,以便适应内容的尺寸。在IE6下,元素的高度根据自动撑开。

3.png

overflow:auto

如果把元素的 overflow属性设置为 auto,则滚动条只在需要的时候出现,也就是当内容溢出元素时自动出现滚动条(溢出的内容滑动滚动条可以显示),没有溢出元素时不出现。就以overflow:visible上面提到的案例来说,效果如下:

.box{
   
   
    width:150px;
    height:150px;
    overflow: auto;
    background:pink;
    color:#666;
}

4.png

overflow:hidden

如果把元素的 overflow属性设置为 hidden,情况则与 overflow:visible 相反,它会把超出盒子的内容全部隐藏掉。就以overflow:visible上面提到的案例来说,效果图如下:

.box{
   
   
    width:150px;
    height:150px;
    overflow: hidden;
    background:pink;
    color:#666;
}

5.png

注意:这种情况下,因为盒子没有出现滚动条,所以对用户来说,被隐藏的内容就彻底看不到。overflow:hidden也可用于清除浮动。具体清除浮动的方法可参考 CSS 浮动和清除浮动方法总结

overflow:scroll

如果把 overflow属性设置为 scroll,它将会隐藏渲染到盒子之外的内容,但会在盒子内部提供一个滚动条,从而可以查看剩下的内容。就以overflow:visible上面提到的案例来说,效果图如下:

.box{
   
   
    width:150px;
    height:150px;
    overflow: scroll;
    background:pink;
    color:#666;
}

6.png

这种情况下,无论内容是否溢出,都会在水平方向(overflow-x)和垂直方向(overflow-y)同时出现滚动条。

设置overflow失效的情况

绝对定位元素与固定定位元素不总是被父级overflow属性剪裁,尤其是当overflow在绝对定位元素及其包含块之间的时候,就以overflow:hidden上面提到的案例来说,这里我添加了一个.big.box 包住,并给 .box 设置了绝对定位,效果图如下:

<div class="big">
    <div class="box">
        <p>
            在CSS中,如果给一个盒子设置了固定的宽度与高度,但内容过多就会溢出盒子本身的宽度或高度。
            此时,就可以使用 overflow 属性来控制内容溢出时的处理方式。那么接下来就开始来学习这个属性吧!
        </p>
    </div>
</div>
.big{
   
   
    width:150px;
    height:150px;
    overflow: hidden;
}
.box{
   
   
    width:150px;
    height:150px;
    position: absolute;
    background:pink;
    color:#666;
}

7.png

因为绝对定位是相对于父元素定位的,所以绝对定位元素无法被它的父级元素overflow属性剪裁 ,父级元素的overflow属性就会失效。这里父元素 .big 的 'overflow: hidden;' 就失效了,怎样来解决这个问题呢?==那就给父级设置position:absolute或fixed或relative,父级元素的overflow属性就会生效啦==。这里我们给 .big设置一个 position: relative;属性就可以了,效果如下:

.big{
   
   
    width:150px;
    height:150px;
    position: relative;
    overflow: hidden;
}
.box{
   
   
    width:150px;
    height:150px;
    position: absolute;
    background:pink;
    color:#666;
}

8.png


以上仅是个人见解,若有不足之处欢迎在下方评论指出,那就先分享到这里!! :smile: 后续继续更新!!

目录
相关文章
|
2天前
|
前端开发
页面无法滑动-CSS: touch-action属性
页面无法滑动-CSS: touch-action属性
20 0
|
2天前
|
容器
mui.css 滚动条消失 导致超出部分无法显示 overflow属性
mui.css 滚动条消失 导致超出部分无法显示 overflow属性
10 0
|
20小时前
|
前端开发 开发者 UED
深入理解CSS属性“flex:1”的奥秘
深入理解CSS属性“flex:1”的奥秘
|
21小时前
|
前端开发
css文本处理,单行多行溢出隐藏,首行缩进2字符,
css文本处理,单行多行溢出隐藏,首行缩进2字符,
4 0
|
2天前
|
前端开发
【Web前端】CSS基本语法规范和引入方式&&常见选择器用法&&常见元素属性
【Web前端】CSS基本语法规范和引入方式&&常见选择器用法&&常见元素属性
|
2天前
|
前端开发 容器
css 中可以让文字在垂直和水平方向上重叠的两个属性是什么?
css 中可以让文字在垂直和水平方向上重叠的两个属性是什么?
9 1
|
2天前
|
前端开发
css样式字体、文本、背景属性,盒子模型详解,轻松调教出优美的字体和网页背景色
css样式字体、文本、背景属性,盒子模型详解,轻松调教出优美的字体和网页背景色
|
2天前
|
前端开发
CSS列表属性
CSS列表属性。
18 5
|
2天前
|
前端开发 UED
CSS cursor的一些相关属性
CSS cursor的一些相关属性
|
2天前
|
前端开发
css的一些属性
css的一些属性