码迷,mamicode.com
首页 > Web开发 > 详细

CSS脱离文档流

时间:2015-12-30 13:30:02      阅读:963      评论:0      收藏:0      [点我收藏+]

标签:

元素脱离文档流之后,相当于农民伯伯被没收了土地,但是还是有户口的,仍然是国家的公民,脱离文档流的元素仍然在dom树结构中。其占据的空间被其他元素使用,两者重叠都是可以的。

从知乎来搬来的,以防源文件被删

著作权归作者所有。
商业转载请联系作者获得授权,非商业转载请注明出处。
作者:张秋怡
链接:https://www.zhihu.com/question/24529373/answer/29135021
来源:知乎

下文中文档的HTML代码如下:
<body>
	<div id="outofnormal">
		Out of normal: 
		Lorem ipsum dolor sit amet, consectetur adipisicing elit. Sequi esse impedit autem praesentium magni culpa, amet corporis, veniam consequatur voluptates temporibus. Voluptates eius similique asperiores cupiditate fugit hic atque quisquam?
	</div>
	<h2>Normal Content</h2>
	<p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Nostrum praesentium nam tempora beatae quis nobis laboriosam alias aliquid, tenetur exercitationem. Odio, aperiam, illo! Eveniet natus dignissimos architecto velit eligendi id!</p>
	<p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Rem reprehenderit velit nam delectus distinctio at unde aliquid officia illo, tempore vitae et incidunt non, ut eos nesciunt quaerat. Enim, minus.</p>
</body>
CSS代码如下,为了看得更清楚,加一个padding
#outofnormal {
	width: 200px;
	background-color: cyan;
	padding: 10px;
}

首先普通情况下(也就是在normal flow里)是这样的
要被玩的div:
技术分享
跟在后面的h2:
技术分享
可以看到两者是垂直排列,padding互相顶着。3D视图的话就是这样,大家排排坐:
技术分享

第二种情况:
加上float:left了之后,蓝色的div就脱离文档流了,变成了这样:
技术分享
因为蓝色的div脱离了文档流,跟在后面的h2和p的盒子都当做没看到这个div的样子去定位,所以他们都顶着浏览器左边和顶部的边框。但是有趣的是,h2和p里面的文本(属于content flow)却都看到了这个被float的div,在自己的盒子里往右推,飘到了蓝色div的边上。这就是float的特性,其他盒子看不见被float的元素,但是其他盒子里的文本看得见。
技术分享3D视图的话就是这样。我插~
技术分享我插~
技术分享我插~
技术分享
为什么能插呢?因为蓝色div被旁边的盒子无视了呀~

第三种情况:absolute positioning。
删掉float: left,加上postion: absolute。和float一样的是,旁边的盒子无视了蓝色div的存在,也是顶着左边边框定位。但是~ 文本也无视了蓝色div的存在,顶着左边边框定位!
技术分享技术分享
3D视图下也是成功无视之,插入~
技术分享
总结:
脱离文档流,也就是将元素从普通的布局排版中拿走,其他盒子在定位的时候,会当做脱离文档流的元素不存在而进行定位。需要注意的是,使用float脱离文档流时,其他盒子会无视这个元素,但其他盒子内的文本依然会为这个元素让出位置,环绕在周围。而对于使用absolute positioning脱离文档流的元素,其他盒子与其他盒子内的文本都会无视它。
 

CSS脱离文档流

标签:

原文地址:http://www.cnblogs.com/pmx-pmx/p/5088194.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!