სხვადასხვა სიგანის ელემენტები და ფლექს ბლოკების შეკუმშვადობა CSS-ში
ახლა დავუშვათ, რომ ჩვენს ელემენტებს აქვთ სხვადასხვა სიგანე. ამ შემთხვევაში, მოწყვეტილი ნაწილი იქნება პროპორციული ამ ელემენტის სიგანის და გამოითვლება შემდეგი ფორმულით: უარყ. თავის. სივრცე * (ელემენტის სიგანე / ყველა ელემენტის სიგანეთა ჯამი).
დავუშვათ, გვაქვს 4 ელემენტი. დავუშვათ
პირველი ელემენტის სიგანე უდრის 400px,
დანარჩენი ელემენტების სიგანე - 200px,
ხოლო მშობლის სიგანე 900px.
ელემენტების საერთო სიგანე უდრის:
400px + 3 * 200px = 1000px
მაშინ უარყოფითი თავისუფალი სივრცე იქნება ტოლი:
1000px - 900px = 100px
ვიპოვოთ რამდენი მოეწყვიტება პირველ ელემენტს:
100px * (400px / 1000px) = 40px
ანუ მისი სიგანე იქნება ტოლი:
400px - 40px = 360px
ვიპოვოთ რამდენი მოეწყვიტება თითოეულ დანარჩენ ელემენტს:
100px * (200px / 1000px) = 20px
ანუ ამ ელემენტების სიგანე იქნება ტოლი:
200px - 20px = 180px
რეალიზება გაუკეთეთ აღწერილ ბლოკებს და შეამოწმეთ გაზომვით, რომ ელემენტების სიგანე მართლაც იქნება ტოლი ჩვენს მიერ გამოთვლილის.
გამოთვალეთ ბლოკების სიგანე და შემდეგ შეამოწმეთ გათვლები გაზომვით:
<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: 300px;
height: 200px;
border: 1px solid red;
}
.child {
height: 50px;
border: 1px solid green;
}
.elem1 {
width: 300px;
}
.elem2 {
width: 100px;
}
.elem3 {
width: 100px;
}