摘要:一個元素如果設(shè)置了但沒有設(shè)置此元素的位置在哪在涉及到絕對定位元素的位置問題時一個重要的概念是想要了解元素的位置還得找到此元素的才行如下是我進行的一系列測試以及對測試結(jié)果的試探性解釋文中的英文術(shù)語都不翻譯方便直接查或者其他技術(shù)文檔請持有懷疑精
一個元素如果設(shè)置了"position: absolute;", 但沒有設(shè)置top, right, bottom, left, 此元素的位置在哪?
在涉及到絕對定位元素的位置問題時, 一個重要的概念是containing block, 想要了解元素的位置, 還得找到此元素的containing block才行. 如下是我進行的一系列測試, 以及對測試結(jié)果的試探性解釋.
文中的英文術(shù)語都不翻譯, 方便直接查W3C或者其他技術(shù)文檔.
請持有懷疑精神閱讀此文, 歡迎討論.
http://jsfiddle.net/medifle/s00Laa0a/3
上面的例子沒有對任何元素設(shè)置"position: absolute;"
http://jsfiddle.net/medifle/9qnp9uh4/1
增加如下代碼
span.left { margin-right: 10px; padding-right: 10px; } span.inner { position: absolute; }
span.inner 只設(shè)置"position: absolute;", 沒有設(shè)置top, right, bottom或left. 此時top, right, bottom或left的initial value是auto.
現(xiàn)在, 嘗試用chrome開發(fā)者工具對span.inner元素的"position: absolute;"進行勾選或者取消勾選, 看看發(fā)生了什么? (提醒: 在這個例子里, span.inner與span.left元素之間是沒有空白符(white space)的, span.inner內(nèi)部有一個空格, 兩個 .)
取消勾選"position: absolute;"后, 多出一個空白符. 再次勾選后, 多出的那個空白符消失. 這個消失的空白符是誰? 為什么會消失?
現(xiàn)在我們先把span.inner的"position: absolute;"取消勾選. 如果我們再嘗試對span.inner分別設(shè)置"float: left;", "display: inline-block;", "display: table-cell;", "display: table;", "display: inline-table;", "display: inline-flex;", 你會發(fā)現(xiàn)span.inner內(nèi)的第一個空白符(是一個空格)都會發(fā)生同樣的現(xiàn)象: 消失.
消失原因得從上面的一堆屬性種找共同點: BFC(block formatting context). 上面的每一個屬性(包括"position: absolute;")都能夠觸發(fā)一個新的BFC, 所以span.inner里的內(nèi)容進入了BFC后成為了新的一行, 而根據(jù)W3C的規(guī)范:
a sequence of collapsible spaces at the beginning of the line is removed
即行首部分的一個或多個可折疊(collapsible)的空白符是被移除的. 我想這就是消失的原因. 所以, 這個現(xiàn)象并不是"position: absolute;"沒有設(shè)置top, right, bottom, left情況下的專屬, 應(yīng)該可以排除了.
注:
"overflow: hidden;" 不能應(yīng)用于inline box, 不滿足觸發(fā)BFC的條件. 詳情見
flow-root
BFC
"display: table;"通過產(chǎn)生anonymous "table-cell" box觸發(fā)一個新的BFC.
從上面的例子里, 似乎span.inner的containing block的左邊緣就是span.inner前面緊挨著的那個元素的margin右邊緣. 情況是這樣嗎? 繼續(xù)看下一個例子.
https://jsfiddle.net/medifle/t22sng4a/
此例中CSS未變, HTML的span.inner與span.left之間多了一個空白符, span.inner內(nèi)部的第一個空白符(是個空格)去掉了, 留下了兩個 .
Beginning of body contents. Inner contents.
現(xiàn)在, 嘗試用chrome開發(fā)者工具對span.inner元素的"position: absolute;"進行勾選或者取消勾選, 看看發(fā)生了什么?
這一次, 如果取消"position: absolute;"后再嘗試對span.inner分別設(shè)置"float: left;", "display: inline-block;", "display: table-cell;", "display: table;", "display: inline-table;", "display: inline-flex;", 結(jié)果是: 沒變化.
此例與上例的唯一改變就在于空白符的位置, 這說明了 span.inner的containing block的左邊緣應(yīng)該是span.inner前面緊挨著的那個元素(不考慮空白符)的margin右邊緣. 并且left的initial value, 即"auto", 會把span.inner定位到它的containing block的左邊緣 (本文只考慮文本的"direction"為"left-to-right"的情況).
https://jsfiddle.net/medifle/sccpersL/
html有改動, 加了兩個圖片, span與span元素之間沒有空白符, 恢復(fù)span.inner的那個去掉的空白符(是個空格).
Beginning of body contents. Inner contents.
現(xiàn)在測試的是span.inner(別忘了它只設(shè)置了"position: absolute;"且不設(shè)置top, right, bottom, left)的containing block的上邊緣.
嘗試用chrome開發(fā)者工具對span.inner元素的’position: absolute;’進行勾選或者取消勾選, 看看發(fā)生了什么?
span.inner在被賦予’position: absolute;’的時候, 其在垂直方向上的表現(xiàn)與對其設(shè)置"vertical-align: top;"沒有差異. 從上述測試結(jié)果看, span.inner的containing block的上邊緣應(yīng)該與其所處的line box的content box的上邊緣在位置上是一致的.
兩個驗證例子:
http://jsfiddle.net/medifle/3y7ucLLy/
http://jsfiddle.net/medifle/proa0fru/
對于上述的第二個例子, 嘗試用chrome開發(fā)者工具對img.img1元素的’position: absolute;’進行勾選或者取消勾選, 看看發(fā)生了什么? (留意: img.img1和img.img2都設(shè)置了"position: absolute;"且沒有設(shè)置top, right, bottom, left).
結(jié)果說明, 對一個元素(img.img1)進行絕對定位會影響到另一個絕對定位的元素(img.img2)的位置, 當然, 這個"絕對定位"是沒有設(shè)置四個方向?qū)傩缘闹档那闆r.
http://jsfiddle.net/medifle/upg4da8o/
此例CSS變動如下:
.inbox { color: blue; position: absolute; top: -10px; } .floatele { float: right; width: 300px; height:50px; background: tomato; padding: 10px; } .demorel { position: relative; }
HTML如下:
Beginning of body contents.
Inner contents. Inner contents.
此例的第二個"Inner contents.", 即span.inbox設(shè)置了top: -10px; 其他三個方向仍然不設(shè)置, 即為auto. section.demorel設(shè)置了"position: relative;". div.floatele設(shè)置了"float: right;", 此時span.inbox的containing block的左邊緣仍然滿足前面的結(jié)論.
在block box里的情況http://jsfiddle.net/medifle/26dgo5k7/
CSS主要有:
.inbox2 { background: #6c4ecd; width: 50px; height: 50px; position: absolute; } .floatele { float: right; width: 300px; height:50px; background: tomato; padding: 10px; } .demorel { position: relative; }
div.inbox2的containing block的左邊緣和上邊緣都是其直系父元素content box的左邊緣和上邊緣 (content box的邊緣又稱content edge).
但值得注意的是, 此例與常規(guī)絕對定位情況下的區(qū)別:
http://jsfiddle.net/medifle/j7xevk78/
CSS有改變, 包含在HTML內(nèi):
這是一個常規(guī)的絕對定位例子, 因為設(shè)置了top和left的值. 值得注意的一點是, 此時div.inbox2的containing block的左邊緣和上邊緣是其直系父元素的padding edge.
如果div.inbox2的前面有一個block box:
https://jsfiddle.net/medifle/dvcfev3s/3/
此例中有兩個div.inbox2, 在它們之前分別有一個block box, 一個是div.blockbox, 另一個是p元素.
從這個例子可以發(fā)現(xiàn), 如果div.inbox2不是其父元素的第一個元素, 且前面是一個block box, 則div.inbox2的containing block的上邊緣是div.blockbox的margin下邊緣.
小結(jié)當絕對定位且不設(shè)置方向值的元素在inline box里時:
未設(shè)置的方向(top, right, bottom, left)的值是auto.
此元素containing block的左邊緣應(yīng)該是該元素前一個元素(空白符除外)的margin右邊緣.
此元素containing block的上邊緣應(yīng)該是該元素所在的line box的content box的上邊緣
如果left的值為auto, 則該元素會定位到其containing block的左邊緣. 如果top的值為auto, 則該元素會定位到其containing block的上邊緣.
當絕對定位且不設(shè)置方向值的元素在block box里時:
未設(shè)置的方向(top, right, bottom, left)的值是auto.
此元素的containing block的左邊緣應(yīng)該是其父元素創(chuàng)建的content box的左邊緣.
如果該元素前面存在一個與其相鄰的block box, 則該元素的containing block的上邊緣應(yīng)該是這個block box的margin下邊緣.
如果該元素是其父元素的第一個子元素, 則該元素的containing block的上邊緣應(yīng)該是其父元素創(chuàng)建的content box的上邊緣.
如果left的值為auto, 則該元素會定位到其containing block的左邊緣. 如果top的值為auto, 則該元素會定位到其containing block的上邊緣.
本文只探討了元素分別在line box和block box里的containing block的左邊緣和上邊緣(文本的"direction"為默認的"ltr", 即從左到右), 還有更多有待探討.
本文所探討的問題我沒有找到直接相關(guān)的W3C規(guī)范, 如果有請一定要@bolo :)
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/111115.html
摘要:它是用于決定盒子的布局及浮動相互影響范圍的一個區(qū)域。小白反思如果世界的運行都有自我運行的一套機制,那么的世界必然有自己的一套規(guī)則。外邊距合并當時在回答外邊距的問題時,總結(jié)出了合并的一條規(guī)則必須相鄰。 最初的夢 了解BFC后,能夠更深入的明白外邊距合并原理。了解BFC后,能夠更深入的明白浮動的行為。了解BFC后,知識就是你的,總不會吃虧對吧?哈哈 之前有兩篇文章《行內(nèi)元素的一些探索》、《...
摘要:前言致謝本文總結(jié)于張鑫旭老師的深入理解之課程,感謝張老師的辛苦付出難學(xué)的作為前端狗的我們,每天都要和網(wǎng)頁打交道。頁面中任何地方,嵌套或直接放入任何空的,都不會影響原來的布局。比如,給元素聲明,但在中的屬性是。 前言 致謝 本文總結(jié)于 張鑫旭老師的 CSS深入理解之margin課程,感謝張老師的辛苦付出! 難學(xué)的 CSS 作為前端狗的我們,每天都要和網(wǎng)頁打交道。當 UI 將設(shè)計稿發(fā)給...
摘要:概述在世界這本書中有一些黑魔法給列舉出來,在結(jié)合自己的理解。篇幅有點長,希望大家能夠堅持看完,一定會有收獲以下是摘自每章內(nèi)一些重要的概念與技巧。 概述 在《css世界》這本書中有一些黑魔法給列舉出來,在結(jié)合自己的理解。篇幅有點長,希望大家能夠堅持看完,一定會有收獲?。?!以下是摘自每章內(nèi)一些重要的概念與技巧。其中有解決圖片間隙的問題、小圖標與文字居中問題等; ps: 特別是 line-h...
摘要:概述在世界這本書中有一些黑魔法給列舉出來,在結(jié)合自己的理解。篇幅有點長,希望大家能夠堅持看完,一定會有收獲以下是摘自每章內(nèi)一些重要的概念與技巧。 概述 在《css世界》這本書中有一些黑魔法給列舉出來,在結(jié)合自己的理解。篇幅有點長,希望大家能夠堅持看完,一定會有收獲?。。∫韵率钦悦空聝?nèi)一些重要的概念與技巧。其中有解決圖片間隙的問題、小圖標與文字居中問題等; ps: 特別是 line-h...
閱讀 1269·2019-08-30 12:49
閱讀 3112·2019-08-28 18:14
閱讀 821·2019-08-26 11:38
閱讀 1676·2019-08-23 18:23
閱讀 2822·2019-08-23 17:04
閱讀 500·2019-08-23 16:52
閱讀 4018·2019-08-23 16:43
閱讀 2769·2019-08-23 16:12