⊗mkSpFxZG 87 of 128 menu

Flex elements nolltillväxt i CSS

Om flex-grow är noll för ett element, så kommer det elementet inte att delta i fördelningen av ledigt utrymme. Som standard är tillväxtfaktorn just noll, och därför delar element utan angiven flex-grow inte på det lediga utrymmet mellan sig.

Låt oss göra en beräkning som exempel. Antag att vi har tre flex-element, var och en med en bredd på 100px. Låt det första elementet inte ha flex-grow (eller så är det 0), det andra elementet har flex-grow, som är 2, och det tredje - 3.

Antag att förälderns bredd är 500px. Då blir det lediga utrymmet 200px, och en enhet av flex-grow kommer att få 200px / 5 = 40px. Det betyder att bredden på det första elementet förblir 100px, eftersom det inte deltar i fördelningen, bredden på det andra blir 100px + 2 * 40px = 180px, och bredden på det tredje - 100px + 3 * 40px = 220px.

Praktiska uppgifter

I alla uppgifter nedan kommer du att få se någon kod med flex-element som har bredd och flex-grow. Utifrån den presenterade koden, beräkna vilka dimensioner varje element kommer att ha. Kör sedan koden och kontrollera dina beräkningar genom att mäta de faktiska bredderna på elementen.

<div class="parent"> <div class="child elem1">1</div> <div class="child elem2">2</div> <div class="child elem3">3</div> </div> .parent { display: flex; width: 500px; height: 200px; border: 1px solid red; } .child { height: 50px; border: 1px solid green; } .elem1 { width: 200px; flex-grow: 0; } .elem2 { width: 100px; flex-grow: 1; } .elem3 { width: 100px; flex-grow: 1; }
<div class="parent"> <div class="child elem1">1</div> <div class="child elem2">2</div> <div class="child elem3">3</div> </div> .parent { display: flex; width: 900px; height: 200px; border: 1px solid red; } .child { height: 50px; border: 1px solid green; } .elem1 { width: 300px; flex-grow: 0; } .elem2 { width: 200px; flex-grow: 3; } .elem3 { width: 100px; flex-grow: 2; }
<div class="parent"> <div class="child elem1">1</div> <div class="child elem2">2</div> <div class="child elem3">3</div> <div class="child elem4">4</div> </div> .parent { display: flex; width: 700px; height: 200px; border: 1px solid red; } .child { height: 50px; border: 1px solid green; } .elem1 { width: 200px; flex-grow: 0; } .elem2 { width: 200px; flex-grow: 0; } .elem3 { width: 100px; flex-grow: 1; } .elem4 { width: 100px; flex-grow: 1; }
Svenska
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Vi använder kakor för webbplatsens funktion, analys och personalisering. Behandling av data sker i enlighet med Integritetspolicyn.
acceptera alla anpassa avvisa