欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談最全面的水平垂直居中方案與flexbox布局

  發(fā)布時間:2018-08-20 15:47:10   作者:樹輝   我要評論
這篇文章主要介紹了淺談最全面的水平垂直居中方案與flexbox布局 的相關(guān)資料,主要介紹了定長定寬或不定長寬的各類容器的垂直居中以及flexbox,非常具有實用價值,需要的朋友可以參考下

最近又遇到許多垂直居中的問題,這是Css布局當(dāng)中十分常見的一個問題,諸如定長定寬或不定長寬的各類容器的垂直居中,其實都有很多種解決方案。而且在Css3的flexbox出現(xiàn)之后,解決各類居中問題變得更加容易了。搜了搜園子內(nèi)關(guān)于flexbox的文章覺得很多不夠詳盡,故想借介紹flexbox的同時好好總結(jié)一番各類垂直居中的方法。

由簡至繁:

行內(nèi)元素的水平居中

要實現(xiàn)行內(nèi)元素(<span>、<a等)的水平居中,只需把行內(nèi)元素包裹在塊級父層元素(<div>、<li>、<p>等)中,并且在父層元素CSS設(shè)置如下:

  #container{
        text-align:center;
    }

并且適用于文字,鏈接,及其inline或者inline-block、inline-table和inline-flex。

塊狀元素的水平居中

要實現(xiàn)塊狀元素(display:block)的水平居中,我們只需要將它的左右外邊距margin-left和margin-right設(shè)置為auto,即可實現(xiàn)塊狀元素的居中,要水平居中的塊狀元素CSS設(shè)置如下:

#center{
    margin:0 auto;
}

多個塊狀元素的水平居中

要實現(xiàn)多個水平排列的塊狀元素的水平居中,傳統(tǒng)的方法是將要水平排列的塊狀元素設(shè)為display:inline-block,然后在父級元素上設(shè)置text-align:center,達(dá)到與上面的行內(nèi)元素的水平居中一樣的效果。

#container{
    text-align:center;
}

#center{
    display:inline-block;
}

使用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。

#container {
     display: flex;
 }

flexbox的默認(rèn)為一個塊級元素,如果需要定義為一個行內(nèi)級的元素,同理:

#container {
     display: inline-flex;
}

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è)置如下:

#container{
     justify-content:center;
    display:flex;
}

已知高度寬度元素的水平垂直居中

法一.

絕對定位與負(fù)邊距實現(xiàn)。

利用絕對定位,將元素的top和left屬性都設(shè)為50%,再利用margin邊距,將元素回拉它本身高寬的一半,實現(xiàn)垂直居中。核心CSS代碼如下:

#container{
    position:relative;
}

#center{
    width:100px;
    height:100px;
    position:absolute;
    top:50%;
    left:50%;
    margin:-50px 0 0 -50px;
}

法二.

絕對定位與margin。

這種方法也是利用絕對定位與margin,但是無需知道被垂直居中元素的高和寬。核心代碼如下:

#container{
    position:relative;
}

#center{
    position:absolute;
    margin:auto;
    top:0;
    bottom:0;
    left:0;
    right:0;
}

未知高度和寬度元素的水平垂直居中

法一. 當(dāng)要被居中的元素是inline或者inline-block元素

當(dāng)要被居中的元素是inline或者inline-block的時候,可以巧妙的將父級容器設(shè)置為display:table-cell,配合text-align:center和vertical-align:middle即可以實現(xiàn)水平垂直居中。

核心代碼如下:

#container{
    position:relative;
}

#center{
    position:absolute;
    margin:auto;
    top:0;
    bottom:0;
    left:0;
    right:0;
}

法二. Css3顯威力

利用Css3的transform,可以輕松的在未知元素的高寬的情況下實現(xiàn)元素的垂直居中。

核心代碼如下:

#container{
    position:relative;
}

#center{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

法三. flex布局輕松解決

使用flex布局,無需絕對定位等改變布局的操作,可以輕松實現(xiàn)元素的水平垂直居中。

核心代碼如下:

#container{
    display:flex;
    justify-content:center;
    align-items: center;
}

#center{

}

一些總結(jié)

CSS3的transform和flex固然好用,但在項目的實際運用中必須考慮兼容問題,大量的hack代碼可能會導(dǎo)致得不償失。

某些瀏覽器仍需使用前綴寫法:

.flexboxtest{
   display: flex;
   display: -webkit-flex; //Safari仍舊需要使用特定的瀏覽器前綴
 }

文中介紹的flex用法只是一小部分,flex還有著其他強(qiáng)大的功能。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 利用CSS3的flexbox實現(xiàn)水平垂直居中與三列等高布局

    這篇文章給大家介紹了三個小節(jié)的內(nèi)容,其中包括關(guān)于css3中flexbox需要掌握的概念、flexbox實現(xiàn)水平垂直居中對齊和三列等高自適應(yīng)頁腳區(qū)域黏附底部的布局,有需要的可以參考
    2016-09-12
  • Flexbox制作CSS布局實現(xiàn)水平垂直居中的簡單實例

    下面小編就為大家?guī)硪黄狥lexbox制作CSS布局實現(xiàn)水平垂直居中的簡單實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-07-27
  • CSS3的Flexbox骰子布局的實現(xiàn)及問題講解

    骰子布局顧名思義,就是好比骰子的一面最多可以放置9個點,而每個面放置的點數(shù)正好就是一個布局的模型圖,這里我們就帶來CSS3的Flexbox骰子布局的實現(xiàn)及問題講解:
    2016-06-27
  • 基礎(chǔ)的CSS3彈性盒Flexbox布局使用實例

    這篇文章主要介紹了基礎(chǔ)的CSS3彈性盒Flexbox布局使用實例,文中最后也提到了解決兼容性問題的基本方法,需要的朋友可以參考下
    2016-04-08
  • CSS3的Flexbox布局的簡明入門指南

    這篇文章主要介紹了CSS3的Flexbox布局的簡明入門指南,Flexbox在"布局界"可謂風(fēng)光無限,近來Facebook開源的React Native也采用Flexbox來布局,需要的朋友可以參考下
    2016-04-08
  • css使用flexbox布局容器內(nèi)多元素水平居中

    這篇文章主要為大家詳細(xì)介紹了css使用flexbox布局容器內(nèi)多元素水平居中的方法,如何使用flexbox布局多元素水平居中?本文為大家進(jìn)行解答,感興趣的小伙伴們可以參考一下
    2016-03-17

最新評論