⊗mkSpFxSFC 96 of 128 menu

CSS-ში ფლექს ბლოკების შეკუმშვის რეგულირება

ნაგულისხმევად, ყველა ელემენტიდან მოიჭრება ნაჭრები, ელემენტის სიგანის პროპორციულად. თუმცა, შესაძლებელია გაკეთდე ისე, რომ ზოგიერთი ელემენტიდან მოიჭრება დიდი ან პატარა ნაჭრები. ამისთვის არსებობს სპეციალური თვისება flex-shrink.

ეს თვისება წარმოადგენს გარკვეულ წონას, რომელზეც გამრავლდება ელემენტის სიგანე მოჭრილი ნაჭრის გამოთვლისას ზემოთ მოყვანილი ფორმულის მიხედვით. მაგალითად, თუ ელემენტის სიგანე უდრის 200px, ხოლო მისი flex-shrink უდრის 3, მაშინ წონილი (ანუ წონაზე გამრავლებული) ელემენტის სიგანე იქნება ტოლი:

200px * 3 = 600px

ფორმულა flex-shrink-ის გათვალისწინებით ექნება შემდეგი სახი: უარყ. თავის. სივრცე * (ელემენტის წონილი სიგანე / ყველა ელემენტის წონილი სიგანეების ჯამი).

მოდით შევხედოთ მაგალითს. დავუშვათ, ჩვენ გვაქვს 4 ელემენტი. დავუშვათ პირველი ელემენტის სიგანე უდრის 400px, ხოლო flex-shrink უდრის 2, დანარჩენი ელემენტების სიგანე - 200px, ხოლო მათი flex-shrink უდრის 1. დავუშვათ მშობელის სიგანე 900px.

ელემენტების საერთო სიგანე უდრის:

400px + 3 * 200px = 1000px

უარყოფითი თავისუფალი სივრცე იქნება ტოლი:

1000px - 900px = 100px

ელემენტების საერთო წონილი სიგანე უდრის:

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

პირველი ელემენტის წონილი სიგანე უდრის:

400px * 2 = 800px

პირველი ელემენტიდან მოიჭრება შემდეგი ნაჭერი:

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

ელემენტის სიგანე იქნება ტოლი:

400px - 57.14px = 342.86px ~ 343px

დანარჩენი თითოეული ელემენტის წონილი სიგანე უდრის:

200px * 1 = 200px

თითოეული ელემენტიდან მოიჭრება შემდეგი ნაჭერი:

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

ელემენტის სიგანე იქნება ტოლი:

200px - 14.2px = 185.8px ~ 186px

რეალიზება გაუკეთეთ აღწერილ ბლოკებს და შეამოწმეთ გაზომვით, რომ ელემენტების სიგანე მართლაც იქნება ტოლი ჩვენს მიერ გამოთვლილის.

გამოთვალეთ ბლოკების სიგანე, შემდეგ კი შეამოწმეთ გათვლები გაზომვით:

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

გამოთვალეთ ბლოკების სიგანე, შემდეგ კი შეამოწმეთ გათვლები გაზომვით:

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

გამოთვალეთ ბლოკების სიგანე, შემდეგ კი შეამოწმეთ გათვლები გაზომვით:

<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; }
ქართული
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語Қазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
ვებსაიტის მუშაობის, ანალიტიკისა და პერსონალიზაციისთვის ვიყენებთ ქუქი-ფაილებს. მონაცემთა დამუშავება ხდება Კონფიდენციალურობის პოლიტიკის შესაბამისად.
ყველას მიღება პარამეტრები უარყოფა