⊗mkSpFxSFC 96 of 128 menu

Uravnavanje stiskanja fleksibilnih blokov v CSS

Privzeto se vsem elementom odvzamejo koski, sorazmerni s širino elementa. Vendar pa je mogoče narediti tako, da se nekaterim elementom odvzamejo večji ali manjši koski. Za to obstaja posebna lastnost flex-shrink.

Ta lastnost predstavlja določeno utež, s katero se bo pomnožila širina elementa pri izračunu odvzetega koska po že navedeni formuli. Na primer, če je širina elementa enaka 200px, njegov flex-shrink pa je 3, potem bo utežena (tj. pomnožena z utežjo) širina elementa enaka:

200px * 3 = 600px

Formula ob upoštevanju flex-shrink bo imela naslednjo obliko: neg. prostor * (utežena širina elementa / vsota vseh uteženih širin elementov).

Poglejmo si primer. Predpostavimo, da imamo 4 elemente. Naj bo širina prvega elementa enaka 400px, flex-shrink pa 2, širina preostalih elementov - 200px, njihov flex-shrink pa 1. Naj bo širina starša 900px.

Skupna širina elementov je enaka:

400px + 3 * 200px = 1000px

Negativni prosti prostor bo enak:

1000px - 900px = 100px

Skupna utežena širina elementov je enaka:

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

Utežena širina prvega elementa je enaka:

400px * 2 = 800px

Od prvega elementa se bo odvzel naslednji košček:

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

Širina elementa bo enaka:

400px - 57.14px = 342.86px ~ 343px

Utežena širina vsakega od preostalih elementov je enaka:

200px * 1 = 200px

Od vsakega elementa se bo odvzel naslednji košček:

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

Širina elementa bo enaka:

200px - 14.2px = 185.8px ~ 186px

Implementirajte opisane bloke in preverite z merjenjem, da bo širina elementov res enaka tisti, ki smo jo izračunali.

Izračunajte širino blokov in nato preverite izračune z merjenjem:

<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; }

Izračunajte širino blokov in nato preverite izračune z merjenjem:

<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; }

Izračunajte širino blokov in nato preverite izračune z merjenjem:

<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
Za delovanje spletnega mesta, analitiko in personalizacijo uporabljamo piškotke. Obdelava podatkov poteka v skladu s Politiko zasebnosti.
sprejmi vse nastavi zavrni