Տարբեր լայնության տարրեր և ֆլեքս բլոկների սեղմելիությունը 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;
}