這篇文章主要介紹了web開發(fā)中如何實現(xiàn)水平垂直居中與flexbox布局 ,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項目有:申請域名、雅安服務(wù)器托管、營銷軟件、網(wǎng)站建設(shè)、川匯網(wǎng)站維護(hù)、網(wǎng)站推廣。
行內(nèi)元素的水平居中
要實現(xiàn)行內(nèi)元素(、、 等)中,并且在父層元素CSS設(shè)置如下: 并且適用于文字,鏈接,及其inline或者inline-block、inline-table和inline-flex。 塊狀元素的水平居中 要實現(xiàn)塊狀元素(display:block)的水平居中,我們只需要將它的左右外邊距margin-left和margin-right設(shè)置為auto,即可實現(xiàn)塊狀元素的居中,要水平居中的塊狀元素CSS設(shè)置如下: 多個塊狀元素的水平居中 要實現(xiàn)多個水平排列的塊狀元素的水平居中,傳統(tǒng)的方法是將要水平排列的塊狀元素設(shè)為display:inline-block,然后在父級元素上設(shè)置text-align:center,達(dá)到與上面的行內(nèi)元素的水平居中一樣的效果。 使用flexbox實現(xiàn)多個塊狀元素的水平居中 在使用之前,首先介紹一下flexbox。 Flexbox布局(Flexible Box)模塊旨在提供一個更加有效的方式制定、調(diào)整和分布一個容器里的項目布局,即使他們的大小是未知或者是動態(tài)的。是CSS3 中一個新的布局模式,為了現(xiàn)代網(wǎng)絡(luò)中更為復(fù)雜的網(wǎng)頁需求而設(shè)計。 Flexbox 已經(jīng)被瀏覽器快速支持。Chrome 22+, Opera 12.1+, 和 Opera Mobile 12.1+ ,firefox18+已經(jīng)支持了本文中所描述的 Flexbox。 學(xué)會使用flexbox 要為元素設(shè)置flexbox布局,只需將display屬性值設(shè)置為flex。 flexbox的默認(rèn)為一個塊級元素,如果需要定義為一個行內(nèi)級的元素,同理: flexbox由伸縮容器和伸縮項目組成。通過設(shè)置元素的display屬性為flex或者inline-flex可以得到一個伸縮容器。設(shè)置為flex的容器被渲染為一個塊級元素,而設(shè)置為inline-flex的容器則渲染為一個行內(nèi)元素。而每一個被設(shè)置為flex的容器,它的內(nèi)部元素都將變成一個flex項目,即是一個伸縮項目。簡單的說,flex 定義了伸縮容器內(nèi)伸縮項目該如何布局。 回到正題,利用flexbox實現(xiàn)多塊狀元素的水平居中,只需要將父級容器的Css設(shè)置如下: 已知高度寬度元素的水平垂直居中 法一. 絕對定位與負(fù)邊距實現(xiàn)。 利用絕對定位,將元素的top和left屬性都設(shè)為50%,再利用margin邊距,將元素回拉它本身高寬的一半,實現(xiàn)垂直居中。核心CSS代碼如下: 法二. 絕對定位與margin。 這種方法也是利用絕對定位與margin,但是無需知道被垂直居中元素的高和寬。核心代碼如下: 未知高度和寬度元素的水平垂直居中 法一. 當(dāng)要被居中的元素是inline或者inline-block元素 當(dāng)要被居中的元素是inline或者inline-block的時候,可以巧妙的將父級容器設(shè)置為display:table-cell,配合text-align:center和vertical-align:middle即可以實現(xiàn)水平垂直居中。 核心代碼如下: 法二. Css3顯威力 利用Css3的transform,可以輕松的在未知元素的高寬的情況下實現(xiàn)元素的垂直居中。 核心代碼如下: 法三. flex布局輕松解決 使用flex布局,無需絕對定位等改變布局的操作,可以輕松實現(xiàn)元素的水平垂直居中。 核心代碼如下: 一些總結(jié) CSS3的transform和flex固然好用,但在項目的實際運(yùn)用中必須考慮兼容問題,大量的hack代碼可能會導(dǎo)致得不償失。 某些瀏覽器仍需使用前綴寫法: 文中介紹的flex用法只是一小部分,flex還有著其他強(qiáng)大的功能。 感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“web開發(fā)中如何實現(xiàn)水平垂直居中與flexbox布局 ”這篇文章對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)! #container{
text-align:center;
}
#center{
margin:0 auto;
}
#container{
text-align:center;
}
#center{
display:inline-block;
}
#container {
display: flex;
}
#container {
display: inline-flex;
}
#container{
justify-content:center;
display:flex;
}
#container{
position:relative;
}
#center{
width:100px;
height:100px;
position:absolute;
top:50%;
left:50%;
margin:-50px 0 0 -50px;
}
#container{
position:relative;
}
#center{
position:absolute;
margin:auto;
top:0;
bottom:0;
left:0;
right:0;
}
#container{
position:relative;
}
#center{
position:absolute;
margin:auto;
top:0;
bottom:0;
left:0;
right:0;
}
#container{
position:relative;
}
#center{
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
#container{
display:flex;
justify-content:center;
align-items: center;
}
#center{
}
.flexboxtest{
display: flex;
display: -webkit-flex; //Safari仍舊需要使用特定的瀏覽器前綴
}
標(biāo)題名稱:web開發(fā)中如何實現(xiàn)水平垂直居中與flexbox布局
鏈接地址:http://weahome.cn/article/joisdd.html