এই ডেমোতে, আপনি clamp()
ব্যবহার করে প্রস্থ নির্ধারণ করছেন এভাবে: width: clamp(<min>, <actual>, <max>)
।
এটি একটি পরম ন্যূনতম এবং সর্বোচ্চ আকার এবং একটি প্রকৃত আকার সেট করে। মানগুলির সাথে, এটি দেখতে এরকম হতে পারে:
.parent {
width: clamp(23ch, 60%, 46ch);
}
এখানে সর্বনিম্ন আকার হল 23ch
বা 23 অক্ষর একক, এবং সর্বাধিক আকার হল 46ch
, 46 অক্ষর৷ অক্ষর প্রস্থের ইউনিটগুলি উপাদানের ফন্টের আকারের উপর ভিত্তি করে (বিশেষত 0
গ্লিফের প্রস্থ)। 'প্রকৃত' আকার হল 50%, যা এই উপাদানটির মূল প্রস্থের 50% প্রতিনিধিত্ব করে।
clamp()
ফাংশনটি এখানে যা করছে তা এই উপাদানটিকে 50% প্রস্থ ধরে রাখতে সক্ষম করে যতক্ষণ না 50% হয় 46ch
(বিস্তৃত ভিউপোর্টে) বা 23ch
(ছোট ভিউপোর্টে) এর চেয়ে ছোট হয়। ভিডিওতে, দেখুন কিভাবে এই কার্ডের প্রস্থ তার ক্ল্যাম্পড সর্বোচ্চ পয়েন্টে বৃদ্ধি পায় এবং প্যারেন্ট প্রসারিত এবং সঙ্কুচিত হওয়ার সাথে সাথে এটির ক্ল্যাম্পড সর্বনিম্ন পর্যন্ত হ্রাস পায়। তারপর এটিকে কেন্দ্রীভূত করতে অতিরিক্ত বৈশিষ্ট্যগুলি ব্যবহার করে অভিভাবকের মধ্যে কেন্দ্রীভূত থাকে। এটি আরও সুস্পষ্ট লেআউট সক্ষম করে, কারণ পাঠ্যটি খুব বেশি চওড়া ( 46ch
উপরে) বা খুব বেশি চওড়া এবং সরু ( 23ch
এর কম) হবে না।
আপনি প্রতিক্রিয়াশীল টাইপোগ্রাফি বাস্তবায়ন করতে এই কৌশলটি ব্যবহার করতে পারেন। উদাহরণস্বরূপ: font-size: clamp(1.5rem, 20vw, 3rem)
। এই ক্ষেত্রে, একটি শিরোনামের ফন্ট-সাইজ সর্বদা 1.5rem
এবং 3rem
এর মধ্যে আটকে থাকবে কিন্তু ভিউপোর্টের প্রস্থের সাথে মানানসই 20vw
প্রকৃত মানের উপর ভিত্তি করে বৃদ্ধি এবং সঙ্কুচিত হবে।
এটি একটি সর্বনিম্ন এবং সর্বাধিক আকারের মান সহ স্পষ্টতা নিশ্চিত করার জন্য একটি দুর্দান্ত কৌশল, তবে মনে রাখবেন এটি সমস্ত আধুনিক ব্রাউজারে সমর্থিত নয় তাই নিশ্চিত করুন যে আপনার ফলব্যাক আছে এবং আপনার পরীক্ষা করুন৷
<div class="parent">
<div class="card">
<h1>Title Here</h1>
<div class="visual"></div>
<p>Descriptive Text. Lorem ipsum dolor sit, amet consectetur adipisicing elit. Sed est error repellat veritatis.</p>
</div>
</div>
.parent {
display: grid;
place-items: center;
}
.card {
width: clamp(23ch, 60%, 46ch);
display: flex;
flex-direction: column;
padding: 1rem;
}
.visual {
height: 125px;
width: 100%;
}