css之overflow
作者:dolymood
overflow
是一个非常常用的 CSS 属性,一般来说会认为很简单,其实细究之后就会发现他还有很多小特性或者说意想不到的结果;
下面就介绍下(在浏览器环境下)关于 overflow
的小总结。
哪些元素上有效?
首先 overflow
是应用到哪些元素上有效的,任意元素?
当然不是,它只能应用于块容器上。
那什么是块容器呢?
简单来说:除了
table
和可替换(置换)元素之外的块级元素都是块容器元素;
但是反过来说块容器元素一定是块级元素的吗?
当然也是 NO ,这是因为对于非替换的
inline-block
元素和table-cell
元素而言,他们是块容器元素但是却不是块级元素。
作用
overflow
属性指定了一个块容器元素在其内容溢出这个元素的时候,内容是否裁掉。
overflow的值
可以取的值有:
visible
(初始值) hidden
、 scroll
、auto
、inherit
。
下面分别介绍下他们的含义:
visible
这个属性表明内容不会被裁剪,所以说他可能超出渲染,也是初始值。
hidden
这个属性表明内容超出的部分需要裁剪掉。
scroll
这个属性表明超出内容不会裁剪掉,浏览器提供滚动机制来让用户看到超出内容,还有就是不管超出不超出他都是要显示的(也就是浏览器的滚动条背景的那个东东)。
auto
如果超出的话,应该有滚动条。
inherit
继承自他的父级元素(或者祖先元素)。
其他“作用”
overflow
的值为非visible
的时候可以生成新的BFC
(块级格式化上下文),常见的结果就是:消除浮动影响、左侧固定右侧自适应(不需要指定margin-left
)、margin
不再折叠等。overflow:hidden
搭配white-space:nowrap
、text-overflow:ellipsis
实现...
效果。overflow:hidden
可以让1px
(scale(0.5)
这种)显示的更加精细。overflow:hidden
可以解决移动端页面内容(一般文字内容相对多一点的时候效果更明显)会出现“进来左右方向缩小到一块”然后再变为正常布局的 bug ,这个 bug 会引起很明显的闪动效果。
疑问
在某些场景下就会遇到和上边所说的情况不一致的时候,下边来介绍下:
一个页面,什么样式都不设置,但是里边很多内容,此时应该是什么样呢?
首先,初始值是 visible
没错,也就是说所有元素的 overflow
的值都是 visible
的,也就是说没有元素设置 overflow:auto
,但是结果确是浏览器会出现滚动条;这是因为规范规定了在这种情况下浏览器需要表现的像是类似于给 viewport 的根元素设置了 overflow:auto
类似的效果。
magin折叠?考虑下边的页面:
overflow test
先来说理论上的效果应该是:我给 body
设置了 overflow:hidden
,也就意味着 body
元素会生成新的 BFC
,也就意味着此时 .content
的元素的 margin
上边界应该是在 body
元素的顶部开始计算的;但是实际的效果确是:
和设想的很大差异,这里就涉及到了一种特殊情况,那就是如果说 viewport 的根元素 html 的 overflow
的值是 visible
且有 body
元素的情况下,就需要将 body
元素的 overflow
设置的值应用到 viewport 上,而这个 body
元素的 overflow
属性的使用值就是 visible
;正式因为如此,才会出现上图的情况,看起来就像是 body
元素和 .content
元素的 margin
发生了折叠一样的效果。
小结
上边就是关于 overflow
的基础以及一些小特性细节,当然可能还有其他好多未知的“情况”有待发掘,欢迎广大同行来“喷-喷”更多的 overflow
!
转自http://gold.xitu.io/post/581dcefbda2f60005df93b54
css之overflow的更多相关文章
- 深入理解CSS溢出overflow & overflow:hidden真的失效了吗[转载]
深入理解CSS溢出overflow http://www.cnblogs.com/xiaohuochai/p/5289653.html overflow:hidden真的失效了吗 http://www ...
- css中overflow:hidden的属性 可能会导致js下拉菜单无法显示
css中overflow:hidden属性导致ExtJS中无法显示下拉滚动条 overflow属性: visible 默认.内容不会被修剪,会呈现在元素之外. hidden 内容会被修剪,但是浏览器不 ...
- 转:css中overflow:hidden 不起作用了吗?
css中overflow:hidden 不起作用了吗? 有同学遇到这样的问题,现象是给元素设置了overflow:hidden,但超出容器的部分并没有被隐藏,难道是设置的hidden失效了吗?其实看似 ...
- css 溢出overflow
css 溢出overflow 当一个元素被设置为固定大小,在这个元素中的内容如果超出元素的界限,就会出现溢出的现象. 通常情况下我们可以通过overflow来控制这个属性. overflow语法定义 ...
- CSS中overflow:scroll怎么设置只上下滚动而不左右滚动
CSS中"overflow:scroll"默认是左右,上下都滚动.怎么设置只上下滚动而不左右滚动,下面有个不错的解决方法 CSS中"overflow:scroll&quo ...
- 对CSS了解-overflow:hidden
overflow:hidden 列出我在项目中,运用到此属性的例子: (1)暴力清除浮动 <style type="text/css"> .wrap {;backgro ...
- CSS 布局 - Overflow
CSS 布局 - Overflow CSS overflow 属性用于控制内容溢出元素框时显示的方式. 这里的文本内容是可以滚动的,滚动条方向是垂直方向.dd马达价格 这里的文本内容是可以滚动的,滚动 ...
- 眼见为实 — CSS的overflow属性
1. overflow属性 CSS的overflow属性指定当内容溢出一个元素的框,会发生什么.举个栗子: <!DOCTYPE html> <html> <head> ...
- 小tip:纯CSS让overflow:auto页面滚动条出现时不跳动
本文转载于张鑫旭博客,原文地址:http://www.zhangxinxu.com/wordpress/?p=4552 一.水平居中布局与滚动条跳动的千年难题 当前web届,绝大多数的页面间布局都是水 ...
随机推荐
- Android Volley入门到精通:使用Volley加载网络图片
在上一篇文章中,我们了解了Volley到底是什么,以及它的基本用法.本篇文章中我们即将学习关于Volley更加高级的用法,如何你还没有看过我的上一篇文章的话,建议先去阅读Android Volley完 ...
- 【Bochs 官方手册翻译】 第一章 Bochs介绍
Bochs 是一个可以完全模拟 Intel x86 计算机的虚拟机系统.它包含了 Intel x86 CPU 仿真.常见设备仿真.以及定制 BIOS.Bochs 可以虚拟多种不同类型的 x86 CPU ...
- IOS - 消息推送原理和实现
一.消息推送原理: 在实现消息推送之前先提及几个于推送相关概念,如下图1-1: 1.Provider:就是为指定IOS设备应用程序提供Push的服务器,(如果IOS设备的应用程序是客户端的话,那么Pr ...
- Delphi字符串与字符数组之间的转换(初始化的重要性)
紧接着上篇博客讲解的内容: 将Char型数组转换为string类型还有下面的这种方法 但是我在测试的时候遇到了一些问题,并在下面进行了解释和总结 先说出我的总结 其实我们在学习编程的时候(比如我之前学 ...
- ODATA WEB API(二)----ODATA服务与客户端
一.概述 ODATA不经可以作为WebAPI建立相应的WEBAPI控制器,还可以建立ODataControl控制器,能够通过插件建立第三方ODataClinet类库:调用和使用数据变得简单可行. 二. ...
- Counterfeit Dollar -----判断12枚钱币中的一个假币
Counterfeit Dollar Time Limit:1000MS Memory Limit:10000KB 64bit IO Format:%I64d & %I64u ...
- SQL分组和聚合(Grouping and Aggregates)
这章应该是难点,也是成为SQL高手的必经之路. 注意有GROUP 语句时,WHERE和HAVING的场合. 前者用于检索前的条件过滤 . 后者用于检索出来结果之后的条件过滤. ========== ; ...
- ShooterGame 学习笔记1 PlayerPawn的两个Mesh的可见性
GameMode Override 为 ShooterGame_TeamDeathMatch GameMode中设置的Default Pawn Class 为 PlayerPawn , PlayerP ...
- POJ2762 Going from u to v or from v to u(单连通 缩点)
判断图是否单连通,先用强连通分图处理,再拓扑排序,需注意: 符合要求的不一定是链拓扑排序列结果唯一,即在队列中的元素始终只有一个 #include<cstdio> #include< ...
- Juery Ajax语法
$.ajax({ url: "/ForgetCard/ForgetLogin",//方法路径URL data: { strUser: $("#textUser" ...