国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

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

newsning / 2610人閱讀

摘要:核心代碼如下法三布局輕松解決使用布局,無需絕對定位等改變布局的操作,可以輕松實現元素的水平垂直居中。

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

由簡至繁:

行內元素的水平居中

要實現行內元素(、、

  • 、

    等)中,并且在父層元素CSS設置如下:

        #container{
            text-align:center;
        }
    并且適用于文字,鏈接,及其inline或者inline-block、inline-table和inline-flex。
    

    Demo

    塊狀元素的水平居中

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

    #center{
        margin:0 auto;
    }


    Demo

    多個塊狀元素的水平居中

    要實現多個水平排列的塊狀元素的水平居中,傳統的方法是將要水平排列的塊狀元素設為display:inline-block,然后在父級元素上設置text-align:center,達到與上面的行內元素的水平居中一樣的效果。

    #container{
        text-align:center;
    }
    
    #center{
        display:inline-block;
    }

    Demo

    使用flexbox實現多個塊狀元素的水平居中

    在使用之前,首先介紹一下flexbox。

    Flexbox布局(Flexible Box)模塊旨在提供一個更加有效的方式制定、調整和分布一個容器里的項目布局,即使他們的大小是未知或者是動態的。是CSS3 中一個新的布局模式,為了現代網絡中更為復雜的網頁需求而設計。

    Flexbox 已經被瀏覽器快速支持。Chrome 22+, Opera 12.1+, 和 Opera Mobile 12.1+ ,firefox18+已經支持了本文中所描述的 Flexbox。

      

    學會使用flexbox

    要為元素設置flexbox布局,只需將display屬性值設置為flex。

    1 #container {
    2     display: flex;
    3 }

    flexbox的默認為一個塊級元素,如果需要定義為一個行內級的元素,同理:

    1 #container {
    2     display: inline-flex;
    3 }

    flexbox由伸縮容器和伸縮項目組成。通過設置元素的display屬性為flex或者inline-flex可以得到一個伸縮容器。設置為flex的容器被渲染為一個塊級元素,而設置為inline-flex的容器則渲染為一個行內元素。而每一個被設置為flex的容器,它的內部元素都將變成一個flex項目,即是一個伸縮項目。簡單的說,flex 定義了伸縮容器內伸縮項目該如何布局。

    回到正題,利用flexbox實現多塊狀元素的水平居中,只需要將父級容器的Css設置如下:

    1 #container{
    2     justify-content:center;
    3     display:flex;
    4 }


    Demo

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

    法一.

    絕對定位與負邊距實現。

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

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


    Demo

    法二.

    絕對定位與margin。

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

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

    Demo

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

    法一. 當要被居中的元素是inline或者inline-block元素

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

    核心代碼如下:

    #container{
        display:table-cell;
        text-align:center;
        vertical-align:middle;
    }
    
    #center{
    
    }

    Demo

    法二. Css3顯威力

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

    核心代碼如下:

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

    Demo

    法三. flex布局輕松解決

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

    核心代碼如下:

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


    Demo

    一些總結

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

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

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

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

    學習前端的同學注意了?。?!
    學習過程中遇到什么問題或者想獲取學習資源的話,歡迎加入前端學習交流群461593224,我們一起學前端!

  • 文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

    轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/92002.html

    相關文章

    • 最全面的水平垂直居中方案flexbox布局

      摘要:核心代碼如下法三布局輕松解決使用布局,無需絕對定位等改變布局的操作,可以輕松實現元素的水平垂直居中。 最近又遇到許多垂直居中的問題,這是Css布局當中十分常見的一個問題,諸如定長定寬或不定長寬的各類容器的垂直居中,其實都有很多種解決方案。而且在Css3的flexbox出現之后,解決各類居中問題變得更加容易了。搜了搜園子內關于flexbox的文章覺得很多不夠詳盡,故想借介紹flexbox...

      luoyibu 評論0 收藏0
    • 最全面的水平垂直居中方案flexbox布局

      摘要:核心代碼如下法三布局輕松解決使用布局,無需絕對定位等改變布局的操作,可以輕松實現元素的水平垂直居中。 最近又遇到許多垂直居中的問題,這是Css布局當中十分常見的一個問題,諸如定長定寬或不定長寬的各類容器的垂直居中,其實都有很多種解決方案。而且在Css3的flexbox出現之后,解決各類居中問題變得更加容易了。搜了搜園子內關于flexbox的文章覺得很多不夠詳盡,故想借介紹flexbox...

      chenjiang3 評論0 收藏0
    • 【前端】這可能是你看過最全的css居中解決方案了~

      摘要:水平居中行內元素解決方案適用元素文字,鏈接,及其其它或者類型元素,,部分代碼文字元素鏈接元素鏈接元素鏈接元素部分代碼解決方案將元素包裹在一個屬性為的父級元素中如設置這個父級元素屬性即可現在大家可以看到和中的子元素水平居中了水平居 1.水平居中:行內元素解決方案 適用元素:文字,鏈接,及其其它inline或者inline-*類型元素(inline-block,inline-table,i...

      csRyan 評論0 收藏0
    • 【前端】這可能是你看過最全的css居中解決方案了~

      摘要:水平居中行內元素解決方案適用元素文字,鏈接,及其其它或者類型元素,,部分代碼文字元素鏈接元素鏈接元素鏈接元素部分代碼解決方案將元素包裹在一個屬性為的父級元素中如設置這個父級元素屬性即可現在大家可以看到和中的子元素水平居中了水平居 1.水平居中:行內元素解決方案 適用元素:文字,鏈接,及其其它inline或者inline-*類型元素(inline-block,inline-table,i...

      Simon 評論0 收藏0

    發表評論

    0條評論

    最新活動
    閱讀需要支付1元查看
    <