flex:1詳解(轉)


轉載自:https://blog.csdn.net/fengyjch/article/details/79047908

flex 是 flex-growflex-shrinkflex-basis的縮寫

flex 的默認值是以上三個屬性值的組合,flex 的默認值是 0 1 auto。

當 flex 取值為 none,則計算值為 0 0 auto;

當 flex 取值為 auto,則計算值為 1 1 auto;

當 flex 取值為一個非負數字,則該數字為 flex-grow 值,flex-shrink 取 1,flex-basis 取 0%,如下是等同的:

.item {flex: 1;}
.item {
    flex-grow: 1;
    flex-shrink: 1;
    flex-basis: 0%;
}

當 flex 取值為一個長度或百分比,則視為 flex-basis 值,flex-grow 取 1,flex-shrink 取 1,有如下等同情況

.item-1 {flex: 0%;}
.item-1 {
    flex-grow: 1;
    flex-shrink: 1;
    flex-basis: 0%;
}
.item-2 {flex: 24px;}
.item-1 {
    flex-grow: 1;
    flex-shrink: 1;
    flex-basis: 24px;
}

當 flex 取值為兩個非負數字,則分別視為 flex-grow 和 flex-shrink 的值,flex-basis 取 0%,如下是等同的:

.item {flex: 2 3;}
.item {
    flex-grow: 2;
    flex-shrink: 3;
    flex-basis: 0%;
}

當 flex 取值為一個非負數字和一個長度或百分比,則分別視為 flex-grow 和 flex-basis 的值,flex-shrink 取 1,如下是等同的:

.item {flex: 2333 3222px;}
.item {
    flex-grow: 2333;
    flex-shrink: 1;
    flex-basis: 3222px;
}

flex-basis 規定的是子元素的基准值。

    <div class="parent">
        <div class="item-1"></div>
        <div class="item-2"></div>
        <div class="item-3"></div>
    </div>
     
    <style type="text/css">
        .parent {
            display: flex;
            width: 600px;
        }
        .parent > div {
            height: 100px;
        }
        .item-1 {
            width: 140px;
            flex: 2 1 0%;
            background: blue;
        }
        .item-2 {
            width: 100px;
            flex: 2 1 auto;
            background: darkblue;
        }
        .item-3 {
            flex: 1 1 200px;
            background: lightblue;
        }
    </style>
  • 主軸上父容器總尺寸為 600px

  • 子元素的總基准值是:0% + auto + 200px = 300px,其中

    1. - 0% 即 0 寬度
    2. - auto 對應取主尺寸即 100px
  • 故剩余空間為 600px - 300px = 300px

  • 伸縮放大系數之和為: 2 + 2 + 1 = 5

  • 剩余空間分配如下:

    1. - item-1 和 item-2 各分配 2/5,各得 120px
    2. - item-3 分配 1/5,得 60px
  • 各項目最終寬度為:

    1. - item-1 = 0% + 120px = 120px
    2. - item-2 = auto + 120px = 220px
    3. - item-3 = 200px + 60px = 260px
  • 當 item-1 基准值取 0% 的時候,是把該項目視為零尺寸的,故即便聲明其尺寸為 140px,也並沒有什么用,形同虛設

  • 而 item-2 基准值取 auto 的時候,根據規則基准值使用值是主尺寸值即 100px,故這 100px 不會納入剩余空間


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM