css - 百分比min-height的一個問題
問題描述
直接上代碼吧
<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <title>Document</title> <style>* { margin: 0; padding: 0;}html { height: 100%;}body { min-height: 100%;}#main { background-color: #333; color: #eee; min-height: 100%;} </style></head><body><p id='main'> This is main section</p></body></html>
https://jsfiddle.net/yaxin/rj7Ljwyx/
上面的代碼中,html和body都已經(jīng)是100%了也就是說body是有高度的,但是為很么#main元素沒有撐開還是一行字體的高度。
當body設(shè)置height而不是min-height為100%時可以實現(xiàn)上述需求,但是為什么?
問題解答
回答1:樓上所有回答設(shè)置height:100%的,難道沒看到題主“當body設(shè)置height而不是min-height為100%時可以實現(xiàn)上述需求,但是為什么?”這句話嗎?
題主是要問為什么?
我來說說鄙人的理解:
1.height的百分比
當我們給塊元素設(shè)置百分比高度時,往往沒能看到效果.因為百分比的大小是相對其最近的父級元素的高的大小,也就是說,其最近的父級元素應(yīng)該有一個明確的高度值才能使其百分比高度生效.
2.min-height的百分比
設(shè)置min-height的元素即使內(nèi)容的高度很少時也能撐開到min-height設(shè)置的高度;當內(nèi)容的高度大于min-height時就設(shè)置為內(nèi)容的高度.
要使min-height的百分比值生效,其父元素的height值必須為一個固定的高度或者是一個有效的百分比高度.
值得注意的是,父元素設(shè)置了有效的min-height但沒有設(shè)置height屬性時,子元素的height和min-height的百分比不會生效.因為設(shè)置height和min-height必須基于一個設(shè)置了固定高度或者是一個有效百分比高度的父元素.
html { height: 100%;}body { min-height: 100%;}#main { background-color: #333; color: #eee; min-height: 100%;}
題主這種多層百分比高度嵌套的風格,應(yīng)該盡量避免,因為子元素百分比高度基于父元素百分比高度的前提是父元素的父元素必須有一個明確的高度。
補充:不但height如此, width也是一樣。《css權(quán)威指南》指出height width百分數(shù)是相對于包含塊的。《css權(quán)威指南》又指出(P180),如果沒有顯示聲明包含塊的height,百分數(shù)高度會重置為auto,所以上面html 的height設(shè)置為任何值都跟設(shè)置沒設(shè)置一樣。
回答2:設(shè)置成height 不能設(shè)置min-height
回答3:html,body {
height: 100%; }回答4:
html,body { height: 100%;}回答5:
body和html標簽比較特殊需要都設(shè)置height:100%才能使得body內(nèi)的子元素height使用百分比。
相關(guān)文章:
1. 運行python程序時出現(xiàn)“應(yīng)用程序發(fā)生異常”的內(nèi)存錯誤?2. 小白學python的問題 關(guān)于%d和%s的區(qū)別3. macos - 無法source activate python274. javascript - npm run build后調(diào)用api返回index.html5. android - 如何實現(xiàn)QQ pad 點擊右側(cè)輸入框,只頂右側(cè)的布局,左側(cè)布局不動6. css3 - css怎么做出這樣的效果?7. html5 - 前端面試碰到了一個緩存數(shù)據(jù)的問題,來論壇上請教一下8. github - 求助大神啊,win10 git clone error,折騰了幾天都不行,以前原本好好的,突然就這樣了9. html - vue里面:src在IE(9-11)下不顯示圖片10. css - 關(guān)于background-position百分比的問題?

網(wǎng)公網(wǎng)安備