摘要:元素框從文檔流完全刪除,并相對(duì)于其包含塊定位。產(chǎn)生折疊的必備條件必須是鄰接的而根據(jù)規(guī)范,兩個(gè)是鄰接的必須滿足以下條件必須是處于常規(guī)文檔流非和絕對(duì)定位的塊級(jí)盒子并且處于同一個(gè)當(dāng)中。
1.浮動(dòng)元素有什么特征?對(duì)父容器、其他浮動(dòng)元素、普通元素、文字分別有什么影響?
何謂浮動(dòng)元素?有什么特征?
所謂浮動(dòng)元素,即是設(shè)置了浮動(dòng)屬性的元素。其特征為:
1.浮動(dòng)的框可以向左或者向右移動(dòng),直到它的外邊緣碰到包含框(其父元素)或者另一個(gè)浮動(dòng)框?yàn)橹梗@條屬性也就意味著浮動(dòng)元素可以像行內(nèi)元素的樣式一樣水平排列,但如果高度設(shè)置存在問題,那么多個(gè)浮動(dòng)元素水平排列會(huì)存在“卡住”的情況,簡(jiǎn)單的測(cè)試一下: 框3就被框1卡住了
2.浮動(dòng)的框不在文檔的普通流中,所以文檔普通流中的塊框感知不到浮動(dòng)框的存在;
3.在css中任何元素都可以浮動(dòng),浮動(dòng)元素會(huì)生成一個(gè)塊級(jí)框,而不論該元素本身是什么元素。
對(duì)父容器、其他浮動(dòng)元素、普通元素、文字分別有什么效果?
浮動(dòng)最初的目的是為了實(shí)行文字的環(huán)繞效果.
- [簡(jiǎn)單測(cè)試1](http://js.jirengu.com/godicuyewi/2/edit) 根據(jù)測(cè)試可以看出: - 對(duì)于處于文檔普通流中的塊級(jí)元素而言,它無法感知到浮動(dòng)元素的存在,故實(shí)際的效果為浮動(dòng)元素覆蓋了塊級(jí)元素的一部分,當(dāng)然也可以說塊級(jí)元素的一部分鉆到了浮動(dòng)元素的下面; - 而塊級(jí)元素包含的文本則可以感知到浮動(dòng)元素的存在(設(shè)定如此),因此環(huán)繞著浮動(dòng)元素排列。 - 那么除了文本之外,像圖片(一般認(rèn)為圖片是行內(nèi)元素),一些表單元素(如單行文本域、單行密碼域、單選按鈕、多選按鈕、多行文本域、下拉菜單、上傳域、隱藏域、提交按鈕、普通按鈕)這些行類元素,他們產(chǎn)生行類框是否能夠識(shí)別到浮動(dòng)元素了?這個(gè)待測(cè)試。。。。。 - [簡(jiǎn)單測(cè)試二](http://js.jirengu.com/viyodokeke/4/edit) - 如果一個(gè)父元素包含浮動(dòng)元素,按照設(shè)想,應(yīng)該是浮動(dòng)元素在父元素的框內(nèi)向左浮動(dòng)或者向右浮動(dòng),然而實(shí)際測(cè)試發(fā)現(xiàn),父元素未被浮動(dòng)元素?fù)伍_,父元素的高度坍塌。2.清除浮動(dòng)指什么? 如何清除浮動(dòng)? 兩種以上方法
清除浮動(dòng)指什么?
由測(cè)試2可以看出,浮動(dòng)元素會(huì)脫離文檔的普通流,而其父容器在普通流中,則存在父元素高度坍塌問題,如果我們希望浮動(dòng)元素在其父容器內(nèi)部浮動(dòng),則需要清除浮動(dòng),而浮動(dòng)元素的能夠浮動(dòng),是因?yàn)榘鼑男锌蚩s短了,從而給浮動(dòng)元素留下了空間,浮動(dòng)原理簡(jiǎn)述,而清除浮動(dòng)就是讓包圍浮動(dòng)元素的行框恢復(fù)原長(zhǎng)度,但浮動(dòng)元素客觀存在(雖然不在普通文檔流中),占據(jù)了一定空間,為了恢復(fù)原長(zhǎng)度,行框應(yīng)該向下或向上移動(dòng),直到左右沒有浮動(dòng)元素為止(即給浮動(dòng)元素上面或下面添加了足夠的清除空間),這樣也就恢復(fù)了原長(zhǎng)度。
如何清除浮動(dòng)?
清除浮動(dòng)主要是兩種方法,即使用clear屬性 ,或者BFC清除浮動(dòng)。
W3c school中一些參考資料
css中有3中定位機(jī)制,即普通流,絕對(duì)定位以及浮動(dòng)。通過position可以選擇4種定位方式:
static
元素框正常生成。塊級(jí)元素生成一個(gè)矩形框,作為文檔流的一部分,行內(nèi)元素則會(huì)創(chuàng)建一個(gè)或多個(gè)行框,置于其父元素中。
relative
元素框偏移某個(gè)距離。元素仍保持其未定位前的形狀,它原本所占的空間仍保留。
absolute
元素框從文檔流完全刪除,并相對(duì)于其包含塊定位。包含塊可能是文檔中的另一個(gè)元素或者是初始包含塊。元素原先在正常文檔流中所占的空間會(huì)關(guān)閉,就好像元素原來不存在一樣。元素定位后生成一個(gè)塊級(jí)框,而不論原來它在正常流中生成何種類型的框。
fixed
元素框的表現(xiàn)類似于將 position 設(shè)置為 absolute,不過其包含塊是視窗本身。
提示:相對(duì)定位實(shí)際上被看作普通流定位模型的一部分,因?yàn)樵氐奈恢孟鄬?duì)于它在普通流中的位置。
1.普通流,即為設(shè)置元素的默認(rèn)位置;
2.相對(duì)定位,即相對(duì)于元素在文檔流中的默認(rèn)位置進(jìn)行偏移;
3.絕對(duì)定位,即相對(duì)于最近的已包含的祖先元素,如果元素沒有最近的祖先元素,那么則相對(duì)于最初的包含塊。
4.z-index 有什么作用? 如何使用?z-index 屬性設(shè)置元素的堆疊順序。擁有更高堆疊順序的元素總是會(huì)處于堆疊順序較低的元素的前面。
注釋:元素可擁有負(fù)的 z-index 屬性值。
注釋:Z-index 僅能在定位元素上奏效(例如 position:absolute;)!
說明
該屬性設(shè)置一個(gè)定位元素沿 z 軸的位置,z 軸定義為垂直延伸到顯示區(qū)的軸。如果為正數(shù),則離用戶更近,為負(fù)數(shù)則表示離用戶更遠(yuǎn)。
取值與意義
默認(rèn)。堆疊順序與父元素相等。
number 設(shè)置元素的堆疊順序。
inherit 規(guī)定應(yīng)該從父元素繼承 z-index 屬性的值。
簡(jiǎn)單測(cè)試一下:
絕對(duì)定位有偏移
加了負(fù)margin也偏移了
兩者的區(qū)別在于:
position:relative;只相對(duì)自己原本位置發(fā)生偏移,不影響其它普通流中元素的位置。
margin:除了讓元素自身發(fā)生偏移還影響其它普通流中的元素。
BFC是什么?
BFC英文全稱是block formatting context,中文翻譯為塊級(jí)話格式上下文(個(gè)人認(rèn)為這個(gè)翻譯太過直譯了,應(yīng)該采用意譯更好),在css的W3C官方文檔中是這樣介紹的
Floats, absolutely positioned elements, block containers (such as inline-blocks, table-cells, and table-captions) that are not block boxes, and block boxes with "overflow" other than "visible" (except when that value has been propagated to the viewport) establish new block formatting contexts for their contents.
In a block formatting context, boxes are laid out one after the other, vertically, beginning at the top of a containing block. The vertical distance between two sibling boxes is determined by the?"margin"?properties. Vertical margins between adjacent block-level boxes in a block formatting context?collapse.
In a block formatting context, each box"s left outer edge touches the left edge of the containing block (for right-to-left formatting, right edges touch). This is true even in the presence of floats (although a box"s?line boxes?may shrink due to the floats), unless the box establishes a new block formatting context (in which case the box itself?may?become narrower?due to the floats).
For information about page breaks in paged media, please consult the section on?allowed page breaks.
翻譯則為:
浮動(dòng)元素和絕對(duì)定位元素,非塊級(jí)盒子的塊級(jí)容器(例如 inline-blocks, table-cells, 和 table-captions),以及overflow值不為“visiable”的塊級(jí)盒子,都會(huì)為他們的內(nèi)容創(chuàng)建新的BFC(塊級(jí)格式上下文)。
在BFC中,盒子從頂端開始垂直地一個(gè)接一個(gè)地排列,兩個(gè)盒子之間的垂直的間隙是由他們的margin 值所決定的。在一個(gè)BFC中,兩個(gè)相鄰的塊級(jí)盒子的垂直外邊距會(huì)產(chǎn)生折疊。
在BFC中,每一個(gè)盒子的左外邊緣(margin-left)會(huì)觸碰到容器的左邊緣(border-left)(對(duì)于從右到左的格式來說,則觸碰到右邊緣)。
翻譯參考
BFC如何產(chǎn)生?
可見官方的解釋是比較晦澀的,那沒可以先這樣簡(jiǎn)單理解,即BFC是一種獨(dú)立的布局模式,當(dāng)元素滿足上述特征時(shí),即會(huì)為元素及其內(nèi)容創(chuàng)建一個(gè)獨(dú)立BFC布局模式,這種布局模式只對(duì)創(chuàng)建元素及其內(nèi)容有作用,對(duì)外界其他元素則沒有影響。
簡(jiǎn)單點(diǎn)說,當(dāng)對(duì)元素設(shè)置以下屬性就可以生成BFC:
float: left | right;(浮動(dòng)元素)
overflow: hidden | auto | scroll;(overflow值不為visable)
display: table-cell | table-caption | inline-block;(非塊級(jí)元素)
position: absolute | fixed;(絕對(duì)定位元素)
-BFC有什么作用(特性)?
1、BFC會(huì)阻止垂直外邊距(margin-top、margin-bottom)折疊
按照BFC的定義,只有同屬于一個(gè)BFC時(shí),兩個(gè)元素才有可能發(fā)生垂直Margin的重疊,這個(gè)包括相鄰元素,嵌套元素,只要他們之間沒有阻擋(例如邊框,非空內(nèi)容,padding等)就會(huì)發(fā)生margin重疊;
因此要解決margin重疊問題,只要讓它們不在同一個(gè)BFC就行了,但是對(duì)于兩個(gè)相鄰元素來說,意義不大,沒有必要給它們加個(gè)外殼,但是對(duì)于嵌套元素來說就很有必要了,只要把父元素設(shè)為BFC就可以了。這樣子元素的margin就不會(huì)和父元素的margin發(fā)生重疊;
2、 BFC不會(huì)重疊浮動(dòng)元素;
3、BFC可以包含浮動(dòng);
我們可以利用BFC的第三條特性來“清浮動(dòng)”,這里其實(shí)說清浮動(dòng)已經(jīng)不再合適,應(yīng)該說包含浮動(dòng)。也就是說只要父容器形成BFC就可以。
BFC的問題還是需要研究,目前似懂非懂?。。。。。。。?/p> 7.在什么場(chǎng)景下會(huì)出現(xiàn)外邊距合并?如何合并?如何不讓相鄰元素外邊距合并?給個(gè)父子外邊距合并的范例
在CSS當(dāng)中,相鄰的兩個(gè)盒子(可能是兄弟關(guān)系也可能是祖先關(guān)系)的外邊距可以結(jié)合成一個(gè)多帶帶的外邊距。這種合并外邊距的方式被稱為折疊,并且因而所結(jié)合成的外邊距稱為折疊外邊距。
當(dāng)兩個(gè)盒子的外邊距均為正時(shí),折疊外邊距取外邊距更大的那個(gè);
當(dāng)兩個(gè)盒子的外邊距 均為負(fù)時(shí),折疊外邊距取外邊距絕對(duì)值更大的那個(gè);
當(dāng)兩個(gè)盒子的外邊距一正一負(fù)時(shí),折疊外邊距取兩個(gè)外邊距值的和。
產(chǎn)生折疊的必備條件:margin必須是鄰接的!
而根據(jù)w3c規(guī)范,兩個(gè)margin是鄰接的必須滿足以下條件:
1.必須是處于常規(guī)文檔流(非float和絕對(duì)定位)的塊級(jí)盒子,并且處于同一個(gè)BFC當(dāng)中。
2.沒有線盒,沒有空隙(clearance),沒有padding和border將他們分隔開
3.都屬于垂直方向上相鄰的外邊距,可以是下面任意一種情況:
元素的margin-bottom與其下一個(gè)常規(guī)文檔流的兄弟元素的margin-top
height為auto的元素的margin-bottom與其最后一個(gè)常規(guī)文檔流的子元素的margin-bottom
高度為0并且最小高度也為0,不包含常規(guī)文檔流的子元素,并且自身沒有建立新的BFC的元素的margin-top和margin-bottom
以上的條件意味著下列的規(guī)則:
1.創(chuàng)建了新的BFC的元素(例如浮動(dòng)元素或者"overflow"值為"visible"以外的元素)與它的子元素的外邊距不會(huì)折疊
浮動(dòng)元素不與任何元素的外邊距產(chǎn)生折疊(包括其父元素和子元素)
2.絕對(duì)定位元素不與任何元素的外邊距產(chǎn)生折疊
inline-block元素不與任何元素的外邊距產(chǎn)生折疊
3.一個(gè)常規(guī)文檔流元素的margin-bottom與它下一個(gè)常規(guī)文檔流的兄弟元素的margin-top會(huì)產(chǎn)生折疊,除非它們之間存在間隙(clearance)。
4.一個(gè)常規(guī)文檔流元素的margin-top 與其第一個(gè)常規(guī)文檔流的子元素的margin-top產(chǎn)生折疊,條件為父元素不包含 padding 和 border ,子元素不包含 clearance。
5.一個(gè) "height" 為 "auto" 并且 "min-height" 為 "0"的常規(guī)文檔流元素的 margin-bottom 會(huì)與其最后一個(gè)常規(guī)文檔流子元素的 margin-bottom 折疊,條件為父元素不包含 padding 和 border ,子元素的 margin-bottom 不與包含 clearance 的 margin-top 折疊。
6.一個(gè)不包含border-top、border-bottom、padding-top、padding-bottom的常規(guī)文檔流元素,并且其 "height" 為 0 或 "auto", "min-height" 為 "0",其里面也不包含行盒(line box),其自身的 margin-top 和 margin-bottom 會(huì)折疊。
以上引用自
文章來源
簡(jiǎn)單測(cè)試一下父子外邊距合并
代碼1
代碼2
代碼3
代碼4
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/112212.html
摘要:兩個(gè)兄弟盒之間的豎直距離由屬性決定。即使存在浮動(dòng)盡管一個(gè)盒的行盒可能會(huì)因?yàn)楦?dòng)收縮,這也成立。它是塊級(jí)盒布局出現(xiàn)的區(qū)域,也是浮動(dòng)層元素進(jìn)行交互的區(qū)域。定位和清除浮動(dòng)的樣式規(guī)則只適用于處于同一塊格式化上下文內(nèi)的元素。 現(xiàn)在有flex布局等新技術(shù),bfc的效果比如包住元素,進(jìn)行自適應(yīng)布局等已經(jīng)不需要了。現(xiàn)在只有免式的事后才需要知道BFC! 看不懂的定義 CSS規(guī)范中對(duì) BFC 的描述 9....
摘要:中有個(gè)重要的概念,搞懂可以讓我們理解中某些原本詭異的地方。簡(jiǎn)介在解釋之前,先說一下文檔流。我們常說的文檔流其實(shí)分為定位流浮動(dòng)流普通流三種。使用包含浮動(dòng)元素注意,這里觸發(fā)并不能阻止其它形式的脫離文檔流的元素覆蓋正常流元素。 CSS中有個(gè)重要的概念BFC,搞懂BFC可以讓我們理解CSS中某些原本詭異(??)的地方。 1. 簡(jiǎn)介 在解釋BFC之前,先說一下文檔流。我們常說的文檔流其實(shí)分為定位...
摘要:前言本文將帶你重新認(rèn)識(shí)布局,帶你解剖布局原理,前提是你要有基礎(chǔ)本文將解除你在布局方面的疑惑。以下將對(duì)布局元素和文檔流進(jìn)行詳細(xì)講解。而且還能保持文檔流,這是其他元素做不到的。 前言 本文將帶你重新認(rèn)識(shí)CSS布局,帶你解剖布局原理,前提是你要有基礎(chǔ)!本文將解除你在布局方面的疑惑。認(rèn)識(shí)每個(gè)布局元素,了解他們的特性,你才知道為什么會(huì)是這樣的結(jié)果。本文內(nèi)容純屬個(gè)人理解,不代表官方。 此文主要為理...
摘要:并最終窗體自上而下分成一行行,并在每行中從左至右的順序排放元素。宋體清除浮動(dòng)這是專業(yè)術(shù)語,其實(shí)就是需要我們解決浮動(dòng)帶來的影響宋體父元素的高度塌陷宋體。相對(duì)定位的參考點(diǎn)是自身。 一、浮動(dòng) 1.1 各個(gè)語言的主要知識(shí)點(diǎn) HTML:標(biāo)簽語義化(那么怎么樣布局才是合理的?沒有絕對(duì)的對(duì)和錯(cuò)) CSS: 樣式: 布局: 標(biāo)準(zhǔn)流(標(biāo)準(zhǔn)文檔流、普通文檔流):盒子模型(width/height...
摘要:不會(huì)重疊浮動(dòng)元素可以包含浮動(dòng)我們可以利用的第三條特性來清浮動(dòng),這里其實(shí)說清浮動(dòng)已經(jīng)不再合適,應(yīng)該說包含浮動(dòng)。總而言之清理浮動(dòng)兩種方式利用屬性,清除浮動(dòng)使父容器形成 CSS清浮動(dòng)處理(Clear與BFC)在CSS布局中float屬性經(jīng)常會(huì)被用到,但使用float屬性后會(huì)使其在普通流中脫離父容器,讓人很苦惱 1 浮動(dòng)帶來布局的便利,卻也帶來了新問題 復(fù)制代碼 1 2 3 4 ...
閱讀 3063·2021-11-18 10:02
閱讀 3331·2021-11-02 14:48
閱讀 3394·2019-08-30 13:52
閱讀 558·2019-08-29 17:10
閱讀 2085·2019-08-29 12:53
閱讀 1408·2019-08-29 12:53
閱讀 1030·2019-08-29 12:25
閱讀 2165·2019-08-29 12:17