⊗mkSpFxZG 87 of 128 menu

Flex-elementtien nollahalu CSS:ssä

Jos flex-grow on nolla jollekin elementille, niin tämä elementti ei osallistu vapaan tilan jakamiseen. Oletusarvoisesti halulla on nolla-arvo, ja siksi elementit, joille ei ole asetettu flex-grow -arvoa, eivät jaa vapaata tilaa keskenään.

Tehdään esimerkkinä laskelma. Oletetaan, että meillä on kolme flex-elementtiä, joiden kukin leveys on 100px. Oletetaan, että ensimmäisellä elementillä ei ole flex-grow -arvoa (tai se on yhtä suuri kuin 0), toisella elementillä on flex-grow, yhtä suuri kuin 2, ja kolmannella - yhtä suuri kuin 3.

Oletetaan, että vanhemman leveys on 500px. Silloin vapaa tila on 200px, ja yhdelle flex-grow -yksikölle tulee 200px / 5 = 40px. Tuloksena ensimmäisen elementin leveys pysyy 100px, koska se ei osallistu jakoon, toisen leveys on 100px + 2 * 40px = 180px, ja kolmannen leveys - 100px + 3 * 40px = 220px.

Käytännön tehtävät

Kaikissa alla olevissa tehtävissä sinulle esitetään koodi flex-elementeillä, joilla on leveys ja flex-grow. Esitetyn koodin perusteella laske, mitkä mitat kullakin elementeistä on. Suorita sitten koodi ja tarkista laskelmat mittaamalla todelliset elementtien leveydet.

<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; }
Suomi
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Käytämme evästeitä verkkosivuston toiminnalle, analytiikalle ja personoinnille. Tietojen käsittely tapahtuu Tietosuojakäytännön mukaisesti.
hyväksy kaikki mukauta hylkää