html文档流
(1)将窗体自上而下分成一行行, 并在每行中按从左至右的顺序排放元素,即为文档流. (2)每个非浮动块级元素都独占一行, 浮动元素则按规定浮在行的一端. 若当前行容不下, 则另起新行再浮动. (3)内联元素不会独占一行. (4)几乎所有元素(包括块级,内联和列表元素)均可生成子行, 用于摆放子元素. (5)有三种情况将使得元素脱离文档流而存在,分别是浮动(float),绝对定位(position:absolute), 固定定位(position:fixed). (6)浮动元素不占任何正常文档流空间,其定位还是基于正常的文档流,然后从文档流中抽出并尽可能远的移动至左侧或者右侧。文字内容会围绕在浮动元素周围。当一个元素从正常文档流中抽出后,仍然在文档流中的其他元素将忽略该元素并填补他原先的空间。 (7)相对定位,:即相对于元素在文档流中位置进行偏移. 但保留原占位. 绝对定位,:即完全脱离文档流,相对于position属性非static值的最近父级元素进行偏移 固定定位,:即完全脱离文档流, 相对于视区进行偏移. (8)元素浮动之后,会让它跳出文档流,也就是说当它后面还有元素时,其他元素会无视它所占据了的区域,直接在它身下布局。但是文字却会认同浮动元素所占据的区域,围绕它布局,也就是没有拖出文本流。 但是绝对定位后,不仅元素盒子会拖出文档流,文字也会出文本流。那么后面元素的文本就不会在认同它的区域位置,会直接在它后面布局,不会再环绕.