In Flow and Out of Flow - CSS: Cascading Style Sheets 编辑
In the previous guide I explained block and inline layout in normal flow. All elements that are in flow, will be laid out using this method.
In the following example I have a heading, paragraph, a list and a final paragraph which contains a strong
element. The heading and paragraphs are block level, the strong
element inline. The list is displayed using flexbox to arrange the items into a row, however it too is participating in block and inline layout - the container has an outside display
type of block
.
All of the elements can be said to be in flow. Appearing on the page in the order that they are in the source.
Taking an item out of flow
All elements are in-flow apart from:
- floated items
- items with
position: absolute
(includingposition: fixed
which acts in the same way) - the root element (
html
)
Out of flow items create a new Block Formatting Context (BFC) and therefore everything inside them can be seen as a mini layout, separate from the rest of the page. The root element therefore is out of flow, as the container for everything in our document, and establishes the Block Formatting Context for the document.
Floated Items
In this example I have a div
, and then two paragraphs. I’ve added a background colour to the paragraphs, and then floated the div
left. The div
is now out of flow.
As a float it is first laid out according to where it would be in normal flow, then taken out of flow and moved to the left as far as possible.
You can see the background colour of the following paragraph running underneath, it is only the line boxes of that paragraph that have been shortened to cause the effect of wrapping content around the float. The box of our paragraph is still displaying according to the rules of normal flow. This is why, to make space around a floated item, you must add a margin to the item, in order to push the line boxes away from it. You cannot apply anything to the following in-flow content to achieve that.
Absolute Positioning
Giving an item position: absolute
or position: fixed
removes it from flow, and any space that it would have taken up is removed. In the next example I have three paragraph elements, the second element has position
absolute
, with offset values of top: 30px
and right: 30px
. It has been removed from document flow.
Using position: fixed
also removes the item from flow, however the offsets are based on the viewport rather than the containing block.
When taking an item out of flow with positioning, you will need to manage the possibility of content overlapping. Out of flow essentially means that the other elements on your page no longer know that element exists so will not respond to it.
Relative Positioning and Flow
If you give an item relative positioning with position: relative
it remains in flow, however you are then able to use the offset values to push it around. The space that it would have been placed in normal flow is reserved however, as you can see in the example below.
When you do anything to remove, or shift an item from where it would be placed in normal flow, you can expect to need to do some managing of the content and the content around it to prevent overlaps. Whether that involves clearing floats, or ensuring that an element with position: absolute
does not sit on top of some other content. For this reason methods which remove elements from being in-flow should be used with understanding of the effect that they have.
Summary
In this guide we have covered the ways to take an element out of flow in order to achieve some very specific types of positioning. In the next guide we will look at a related issue, that of creating a Block Formatting Context, in Formatting Contexts Explained.
See also
- Learn Layout: Positioning
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论