摘要:常見的布局兩列布局兩欄布局一欄定寬,一欄自適應(yīng),自適應(yīng)的一欄作為內(nèi)容主體。三列布局三列布局也是經(jīng)常使用到的一種布局,它的特點(diǎn)是兩邊兩列固定,中間自適應(yīng)。左右兩欄使用屬性,中間欄使用屬性。
垂直居中 單行文本垂直居中 父元素高度為auto
一個(gè)父元素如果不設(shè)置高度的話,默認(rèn)就是緊包裹著子元素,如果父元素設(shè)置的pading-top和padding-bottom相同,這本身就是一個(gè)垂直居中效果,但是當(dāng)子元素并不是獨(dú)占一行,而是inline元素和inline-block元素組合成一行,比如下面這個(gè)例子:
inline元素和inline-block元素在同一行顯示,由于圖片這個(gè)inline-block元素本身有高度,就會(huì)把整個(gè)行撐開,但是文字和圖片依然在一行,細(xì)看可以發(fā)現(xiàn),圖片本身并沒有和文字最下邊對(duì)齊,這是由于inline-block默認(rèn)帶有vertical-align屬性,其值默認(rèn)為baseline,也就是圖片和文字的baseline對(duì)齊,注意vetical-align只對(duì)inline-block元素有效,這種情況下,只需要對(duì)inline-block元素設(shè)置vertical-align:middle即可實(shí)現(xiàn)垂直居中。效果如下:
父元素height為固定值這種情況只需要在父元素上設(shè)置line-height屬性等于父元素的height屬性即可(line-height = height),這種只適用于單行文本,且父元素高度固定,對(duì)于多行文本就無能為力了。
父元素height固定,子元素是塊元素 子元素高度固定這種情況下可以利用absolute定位來實(shí)現(xiàn)垂直居中。缺點(diǎn)就是脫離了普通文檔流。
.parent { position:relative; } .child { position:absolute; top:50%; height:200px; margin-top:-100px; } // 或者下面的實(shí)現(xiàn)方法 .child { position:absolute; top:0; bottom:0; height:200px; margin:auto 0; }子元素height不固定
該情況下對(duì)子元素是塊級(jí)元素或非塊級(jí)元素均可以。
.parent { display:table-ceil; height:200px; vetical-align:middle; }
該方法由于display:table-ceil屬性的兼容性不夠好,只能在IE8及更高版本使用。
.parent { position:relative; } .child { position:absolute; top:50%; transform:translateY(-50%); }
該方法由于transform:translateY(-50%)屬性的兼容性不夠好,只能在IE9及更高版本使用。
flex.parent { display:flex; align-items:center; }
flex彈性布局更加的靈活簡(jiǎn)單,對(duì)頁面中其他元素的影響更小,在IE11以及更高版本才能兼容,如果是在移動(dòng)端開發(fā),盡量使用該屬性實(shí)現(xiàn)各種復(fù)雜的布局。
常見的布局 兩列布局兩欄布局:一欄定寬,一欄自適應(yīng),自適應(yīng)的一欄作為內(nèi)容主體。
1:使用float + margin屬性。
.left { width:200px; float:left; } .right { margin-left:200px; }
也可以使用absolute定位來實(shí)現(xiàn)。
.container { position:relative; } .left { position:absoulte; left:0; width:200px; } .right { position:absolute; left:200px; right:0; }三列布局
三列布局也是經(jīng)常使用到的一種布局,它的特點(diǎn)是兩邊兩列固定,中間自適應(yīng)。
1:左右兩欄使用float屬性,中間欄使用margin屬性。
左欄右欄中間欄.left,.right { float:left; width:200px; } .right { float:right; } .middle { margin:0 200px; }
該方法必須要將中間欄放在最后,且如果父元素的寬度小于左右兩欄寬度時(shí),右側(cè)欄會(huì)被擠下去。
2:使用position布局
.container { position:relative; } .left,.right { width:200px; left:0; } .right { left:auto; right:0 } .middle { margin:0 200px; }
該方法的缺點(diǎn)是如果父元素有內(nèi)外邊距的時(shí)候,會(huì)導(dǎo)致中間欄的位置出現(xiàn)偏差。
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/115777.html
摘要:現(xiàn)在回到我們這一章節(jié)的標(biāo)題,將它做下補(bǔ)充關(guān)于那些事四之基于構(gòu)架基礎(chǔ)樣式庫基礎(chǔ)庫構(gòu)思為什么要做基礎(chǔ)庫我上一章節(jié)的末尾拋出了幾個(gè)問題假設(shè)你要做一個(gè)游戲單頁面,網(wǎng)頁上并不存在表單內(nèi)容,那么你就要移除一些冗余的代碼,開始自定義樣式來滿足自己的需求。 前言 先來回顧一下前幾章節(jié),我們都說了哪些內(nèi)容: CSS Reset 歷史 與 Normalize.css 介紹 Normalize.css...
摘要:現(xiàn)在回到我們這一章節(jié)的標(biāo)題,將它做下補(bǔ)充關(guān)于那些事四之基于構(gòu)架基礎(chǔ)樣式庫基礎(chǔ)庫構(gòu)思為什么要做基礎(chǔ)庫我上一章節(jié)的末尾拋出了幾個(gè)問題假設(shè)你要做一個(gè)游戲單頁面,網(wǎng)頁上并不存在表單內(nèi)容,那么你就要移除一些冗余的代碼,開始自定義樣式來滿足自己的需求。 前言 先來回顧一下前幾章節(jié),我們都說了哪些內(nèi)容: CSS Reset 歷史 與 Normalize.css 介紹 Normalize.css...
摘要:派生選擇器依據(jù)元素的位置關(guān)系來定義樣式。稱其為上下文選擇器,稱其為派生選擇器。在現(xiàn)在布局中,選擇器常常用于建立派生選擇器。和一樣,也可被用作派生選擇器。 文章大綱來源:【Day 3】HTML復(fù)習(xí) + CSS基礎(chǔ) 初識(shí)CSS 入門CSS 初識(shí)CSS 層疊樣式表(Cascading Style Sheets),即前端常說的CSS。 內(nèi)容引用:CSS 簡(jiǎn)介 樣式解決了什么問題? HTML...
摘要:派生選擇器依據(jù)元素的位置關(guān)系來定義樣式。稱其為上下文選擇器,稱其為派生選擇器。在現(xiàn)在布局中,選擇器常常用于建立派生選擇器。和一樣,也可被用作派生選擇器。 文章大綱來源:【Day 3】HTML復(fù)習(xí) + CSS基礎(chǔ) 初識(shí)CSS 入門CSS 初識(shí)CSS 層疊樣式表(Cascading Style Sheets),即前端常說的CSS。 內(nèi)容引用:CSS 簡(jiǎn)介 樣式解決了什么問題? HTML...
摘要:上面五個(gè)問題就是我總結(jié)的基礎(chǔ)概念,學(xué)習(xí)過程中一定要把它們弄明白別忘了有哦。 請(qǐng)帶著以下幾個(gè)問題進(jìn)行學(xué)習(xí) CSS是什么 CSS的引用方式 CSS選擇器 CSS優(yōu)先級(jí) CSS盒模型 基礎(chǔ)知識(shí)學(xué)習(xí)和實(shí)例演練教程 MDN中css教程CSS基礎(chǔ)學(xué)習(xí)教程(css快速入門)CSS參考手冊(cè)(便于了解更多css屬性)CSS3教程(適用于移動(dòng)端開發(fā)的css新特性) 入門學(xué)習(xí),一定要快,沒有必要花大量時(shí)...
閱讀 2849·2021-11-19 09:40
閱讀 3709·2021-11-15 18:10
閱讀 3289·2021-11-11 16:55
閱讀 1246·2021-09-28 09:36
閱讀 1663·2021-09-22 15:52
閱讀 3376·2019-08-30 14:06
閱讀 1171·2019-08-29 13:29
閱讀 2317·2019-08-26 17:04