⊗mkSpFxSFC 96 of 128 menu

Regulovanie stláčania flex blokov v CSS

Predvolene sa zo všetkých elementov odštipujú kúsky úmerné šírke elementu. Avšak, je možné spraviť to, aby sa z niektorých elementov odštipovali väčšie alebo menšie kúsky. Na to existuje špeciálna vlastnosť flex-shrink.

Táto vlastnosť predstavuje určitú vahu, na ktorú sa vynásobí šírka elementu pri výpočte odštipovaného kúsku podľa už uvedeného vzorca. Napríklad, ak šírka elementu je 200px, a jeho flex-shrink je 3, tak zvážená (t.j. vynásobená vahou) šírka elementu vyjde:

200px * 3 = 600px

Vzorec s prihliadnutím na flex-shrink bude mať nasledujúci tvar: záp. voľný priestor * (zvážená šírka elementu / súčet všetkých zvážených šírok elementov).

Pozrime sa na príklad. Majme 4 elementy. Nech šírka prvého elementu je 400px, a flex-shrink je 2, šírka zvyšných elementov - 200px, a ich flex-shrink je 1. Nech šírka rodiča je 900px.

Súhrnná šírka elementov je:

400px + 3 * 200px = 1000px

Záporný voľný priestor bude:

1000px - 900px = 100px

Súhrnná zvážená šírka elementov je:

400px * 2 + 200px * 1 + 200px * 1 + 200px * 1 = 1400px

Zvážená šírka prvého elementu je:

400px * 2 = 800px

Z prvého elementu sa odštipne nasledujúci kúsok:

100px * (800px / 1400px) = 100px * 0.57 = 57.14px

Šírka elementu bude:

400px - 57.14px = 342.86px ~ 343px

Zvážená šírka každého zo zvyšných elementov je:

200px * 1 = 200px

Z každého elementu sa odštipne nasledujúci kúsok:

100px * (200px / 1400px) = 100px * 0.142 = 14.2px

Šírka elementu bude:

200px - 14.2px = 185.8px ~ 186px

Realizujte opísané bloky a overte meraním, že šírka elementov bude naozaj rovná nami vypočítanej.

Vypočítajte šírku blokov, a potom overte výpočty meraním:

<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: 200px; height: 200px; border: 1px solid red; } .child { height: 50px; border: 1px solid green; } .elem1 { width: 100px; flex-shrink: 2; } .elem2 { width: 100px; flex-shrink: 1; } .elem3 { width: 100px; flex-shrink: 1; }

Vypočítajte šírku blokov, a potom overte výpočty meraním:

<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: 200px; height: 200px; border: 1px solid red; } .child { height: 50px; border: 1px solid green; } .elem1 { width: 100px; flex-shrink: 3; } .elem2 { width: 100px; flex-shrink: 2; } .elem3 { width: 100px; flex-shrink: 1; }

Vypočítajte šírku blokov, a potom overte výpočty meraním:

<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: 500px; height: 200px; border: 1px solid red; } .child { height: 50px; border: 1px solid green; } .elem1 { width: 300px; flex-shrink: 3; } .elem2 { width: 200px; flex-shrink: 2; } .elem3 { width: 200px; flex-shrink: 1; } .elem4 { width: 200px; flex-shrink: 1; }
Slovenčina
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Používame cookies na fungovanie stránky, analýzu a personalizáciu. Spracúvanie údajov prebieha v súlade s Politikou ochrany osobných údajov.
prijať všetky nastaviť odmietnuť