真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

web開發(fā)中如何實(shí)現(xiàn)水平垂直居中與flexbox布局-創(chuàng)新互聯(lián)

這篇文章主要介紹了web開發(fā)中如何實(shí)現(xiàn)水平垂直居中與flexbox布局 ,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

成都創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比旅順口網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式旅順口網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋旅順口地區(qū)。費(fèi)用合理售后完善,10多年實(shí)體公司更值得信賴。

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

要實(shí)現(xiàn)行內(nèi)元素(、、

  • 、

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

      #container{
            text-align:center;
        }

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

    web開發(fā)中如何實(shí)現(xiàn)水平垂直居中與flexbox布局

    塊狀元素的水平居中

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

    #center{
        margin:0 auto;
    }

    web開發(fā)中如何實(shí)現(xiàn)水平垂直居中與flexbox布局

    多個(gè)塊狀元素的水平居中

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

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

    web開發(fā)中如何實(shí)現(xiàn)水平垂直居中與flexbox布局

    使用flexbox實(shí)現(xiàn)多個(gè)塊狀元素的水平居中

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

    Flexbox布局(Flexible Box)模塊旨在提供一個(gè)更加有效的方式制定、調(diào)整和分布一個(gè)容器里的項(xiàng)目布局,即使他們的大小是未知或者是動(dòng)態(tài)的。是CSS3 中一個(gè)新的布局模式,為了現(xiàn)代網(wǎng)絡(luò)中更為復(fù)雜的網(wǎng)頁(yè)需求而設(shè)計(jì)。

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

    學(xué)會(huì)使用flexbox

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

    #container {
         display: flex;
     }

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

    #container {
         display: inline-flex;
    }

    flexbox由伸縮容器和伸縮項(xiàng)目組成。通過設(shè)置元素的display屬性為flex或者inline-flex可以得到一個(gè)伸縮容器。設(shè)置為flex的容器被渲染為一個(gè)塊級(jí)元素,而設(shè)置為inline-flex的容器則渲染為一個(gè)行內(nèi)元素。而每一個(gè)被設(shè)置為flex的容器,它的內(nèi)部元素都將變成一個(gè)flex項(xiàng)目,即是一個(gè)伸縮項(xiàng)目。簡(jiǎn)單的說(shuō),flex 定義了伸縮容器內(nèi)伸縮項(xiàng)目該如何布局。

    回到正題,利用flexbox實(shí)現(xiàn)多塊狀元素的水平居中,只需要將父級(jí)容器的Css設(shè)置如下:

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

    web開發(fā)中如何實(shí)現(xiàn)水平垂直居中與flexbox布局

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

    法一.

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

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

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

    web開發(fā)中如何實(shí)現(xiàn)水平垂直居中與flexbox布局

    法二.

    絕對(duì)定位與margin。

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

    #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í)候,可以巧妙的將父級(jí)容器設(shè)置為display:table-cell,配合text-align:center和vertical-align:middle即可以實(shí)現(xiàn)水平垂直居中。

    核心代碼如下:

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

    web開發(fā)中如何實(shí)現(xiàn)水平垂直居中與flexbox布局

    法二. Css3顯威力

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

    核心代碼如下:

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

    web開發(fā)中如何實(shí)現(xiàn)水平垂直居中與flexbox布局

    法三. flex布局輕松解決

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

    核心代碼如下:

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

    web開發(fā)中如何實(shí)現(xiàn)水平垂直居中與flexbox布局

    一些總結(jié)

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

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

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

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

    感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“web開發(fā)中如何實(shí)現(xiàn)水平垂直居中與flexbox布局 ”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司,,關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!


    分享名稱:web開發(fā)中如何實(shí)現(xiàn)水平垂直居中與flexbox布局-創(chuàng)新互聯(lián)
    網(wǎng)站路徑:http://weahome.cn/article/coeisj.html
  • 其他資訊

    在線咨詢

    微信咨詢

    電話咨詢

    028-86922220(工作日)

    18980820575(7×24)

    提交需求

    返回頂部