⊗mkSpFxGr 86 of 128 menu

CSS-এ ফ্লেক্স এলিমেন্টের লোভ

ধরুন এখন আমাদের কাছে দুটি ফ্লেক্স-ব্লক আছে, একটি সারিতে সাজানো। এই ব্লকগুলির প্রস্থ নির্ধারণ করা হয়েছে 100px, এবং তাদের প্যারেন্টের - 300px:

<div class="parent"> <div class="child">1</div> <div class="child">2</div> </div> .parent { display: flex; width: 300px; height: 200px; border: 1px solid red; } .child { width: 100px; height: 100px; border: 1px solid green; }

:

আপনি দেখতে পাচ্ছেন, আমাদের এলিমেন্টের মোট প্রস্থ প্যারেন্টের প্রস্থের চেয়ে কম, তাই ডানদিকে খালি জায়গা থাকে।

ইচ্ছা করলে এই খালি জায়গাটি আমাদের এলিমেন্টগুলির মধ্যে আনুপাতিকভাবে ভাগ করা যেতে পারে। এটি flex-grow বৈশিষ্ট্য ব্যবহার করে করা হয়, যা ফ্লেক্স-এলিমেন্টগুলিতে নির্দিষ্ট করা হয়। এই বৈশিষ্ট্যের মান একটি মাত্রাহীন সংখ্যা।

আসুন অনুশীলনে দেখি কিভাবে এই বৈশিষ্ট্য কাজ করে।

উদাহরণ

এখন আমাদের কাছে দুটি ফ্লেক্স-ব্লক আছে যার প্রস্থ 100px। তাদের মোট প্রস্থ 200px, এবং প্যারেন্টের প্রস্থ - 300px। এর মানে হল যে 100px মুক্ত স্থান অবশিষ্ট থাকে।

যদি এলিমেন্টগুলিতে flex-grow নির্দিষ্ট না করা থাকে, তবে আমরা কেবল এই মুক্ত স্থানটি দেখতে পাব। যদি এটি তাদের জন্য নির্দিষ্ট করা থাকে, তবে এলিমেন্টগুলির প্রকৃত প্রস্থ নির্দিষ্ট প্রস্থের চেয়ে বেশি হবে - তারা আনুপাতিকভাবে মুক্ত স্থানটি নিজেদের মধ্যে ভাগ করে নেবে এবং এটি তাদের নিজস্ব প্রস্থের সাথে যোগ করবে।

উদাহরণস্বরূপ ধরুন প্রথম এলিমেন্টের flex-grow সমান 1, এবং দ্বিতীয়টির - 3। আসুন গণনা করি, প্রতিটি এলিমেন্ট মুক্ত স্থানের কত অংশ পাবে।

প্রথমে আমাদের সকল এলিমেন্টের flex-grow-এর মোট একক প্রাপ্ত করতে হবে। প্রথম এলিমেন্টের এটি 1, এবং দ্বিতীয়টির - 3। এর মানে হল যে মোট এটি 4

এখন 100px মুক্ত স্থানকে 4 দ্বারা ভাগ করলে আমরা পাই যে 25px পড়ে flex-grow-এর একটি এককের উপর। এর মানে, যে প্রথম এলিমেন্টে একটি একক যোগ হবে flex-grow, অর্থাৎ 25px, এবং দ্বিতীয়টিতে - তিনটি একক, অর্থাৎ 75px

প্রথম এলিমেন্টের প্রস্থ হবে 125px, এবং দ্বিতীয়টির - 175px:

<div class="parent"> <div class="child elem1">1</div> <div class="child elem2">2</div> </div> .parent { display: flex; width: 300px; height: 200px; border: 1px solid red; } .child { height: 50px; border: 1px solid green; } .elem1 { width: 100px; flex-grow: 1; } .elem2 { width: 100px; flex-grow: 3; }

:

উদাহরণ

ধরুন এখন প্যারেন্টের প্রস্থ 400px, প্রথম এলিমেন্টের প্রস্থ 200px, এবং দ্বিতীয় এলিমেন্টের প্রস্থ - 100px। এর মানে, যে মুক্ত স্থান আবার সমান 100px

আসুন প্রতিটি এলিমেন্টে flex-grow নির্দিষ্ট করি, সমান 1। মোট হবে 2, অর্থাৎ 100px মুক্ত স্থান 2 দ্বারা ভাগ করতে হবে। এর মানে হবে যে 50px পড়ে লোভের একটি এককের উপর।

যেহেতু সকল এলিমেন্টের flex-grow-এর মান একই, তাই সকল এলিমেন্টে একই মান যোগ হবে 50px। এর মানে, যে প্রথম এলিমেন্টটি হবে 250px, এবং দ্বিতীয়টি হবে 150px:

<div class="parent"> <div class="child elem1">1</div> <div class="child elem2">2</div> </div> .parent { display: flex; width: 400px; height: 200px; border: 1px solid red; } .child { height: 50px; border: 1px solid green; } .elem1 { width: 200px; flex-grow: 1; } .elem2 { width: 100px; flex-grow: 1; }

:

উদাহরণ

ধরুন আবার প্যারেন্টের প্রস্থ 400px, প্রথম এলিমেন্টের প্রস্থ 200px, এবং দ্বিতীয় এলিমেন্টের প্রস্থ - 100px

আসুন এখন প্রথম এলিমেন্টে flex-grow নির্দিষ্ট করি 3 মানে, এবং দ্বিতীয়টি - 1 মানে। এর মানে হবে যে মোট লোভ 4। তাহলে লোভের একটি একক সমান 100px / 4 = 25px

প্রথম এলিমেন্টে 75px যোগ হবে, এবং এটি হবে 275px, এবং দ্বিতীয়টিতে - 25px, এটি হবে 125px:

<div class="parent"> <div class="child elem1">1</div> <div class="child elem2">2</div> </div> .parent { display: flex; width: 400px; height: 200px; border: 1px solid red; } .child { height: 50px; border: 1px solid green; } .elem1 { width: 200px; flex-grow: 3; } .elem2 { width: 100px; flex-grow: 1; }

:

ব্যবহারিক কাজ

নিচের সকল কাজে আপনাকে কিছু কোড দেওয়া হবে ফ্লেক্স-এলিমেন্ট সহ, যাদের প্রস্থ এবং flex-grow আছে। প্রদত্ত কোডের উপর ভিত্তি করে গণনা করুন, কোন মাত্রা হবে প্রতিটি এলিমেন্টের। তারপর কোডটি চালান এবং আপনার গণনা পরীক্ষা করুন, প্রকৃত এলিমেন্টের প্রস্থ মেপে দেখুন।

<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: 500px; height: 200px; border: 1px solid red; } .child { height: 50px; border: 1px solid green; } .elem1 { width: 200px; flex-grow: 3; } .elem2 { width: 100px; flex-grow: 1; } .elem3 { width: 100px; flex-grow: 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: 700px; height: 200px; border: 1px solid red; } .child { height: 50px; border: 1px solid green; } .elem1 { width: 100px; flex-grow: 1; } .elem2 { width: 100px; flex-grow: 2; } .elem3 { width: 200px; flex-grow: 3; }
<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: 500px; height: 200px; border: 1px solid red; } .child { height: 50px; border: 1px solid green; } .elem1 { width: 100px; flex-grow: 1; } .elem2 { width: 100px; flex-grow: 1; } .elem3 { width: 100px; flex-grow: 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: 1000px; height: 200px; border: 1px solid red; } .child { height: 50px; border: 1px solid green; } .elem1 { width: 200px; flex-grow: 1; } .elem2 { width: 100px; flex-grow: 2; } .elem3 { width: 100px; flex-grow: 4; } .elem4 { width: 100px; flex-grow: 3; }
বাংলা
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
আমরা সাইট পরিচালনা, বিশ্লেষণ এবং ব্যক্তিগতকরণের জন্য কুকি ব্যবহার করি। ডেটা প্রক্রিয়াকরণ গোপনীয়তা নীতি অনুযায়ী করা হয়।
সব গ্রহণ করুন কনফিগার করুন প্রত্যাখ্যান করুন