কন্টেইনার প্রশ্ন এখানে!
উত্তেজনাপূর্ণ খবর—সবচেয়ে বেশি অনুরোধ করা ডেভেলপার বৈশিষ্ট্যগুলির মধ্যে একটি ওয়েব ব্রাউজারে অবতরণ করা শুরু করেছে! Chromium 105 এবং Safari 16 হিসাবে, আপনি এখন আকার-ভিত্তিক কন্টেইনার ক্যোয়ারী তৈরি করতে পারেন এবং এই ব্রাউজারগুলিতে কন্টেইনার কোয়েরি ইউনিট মান ব্যবহার করতে পারেন। আকার-ভিত্তিক কন্টেইনার ক্যোয়ারী এবং cq
ইউনিটগুলি ব্যবহার করা আরও সহজ করার জন্য, Chrome-এর অরোরা টিম আরও ব্রাউজার সমর্থন করতে এবং কেস ব্যবহার করার জন্য কনটেইনার কোয়েরি পলিফিল আপডেট করার জন্য কঠোর পরিশ্রম করেছে যাতে আপনি আজ এই শক্তিশালী বৈশিষ্ট্যটি ব্যবহার করে আত্মবিশ্বাসী বোধ করতে পারেন।
ধারক প্রশ্ন কি?
কন্টেইনার ক্যোয়ারী হল একটি CSS বৈশিষ্ট্য যা আপনাকে স্টাইলিং লজিক লিখতে সক্ষম করে যা একটি অভিভাবক উপাদানের বৈশিষ্ট্যগুলিকে তার বাচ্চাদের স্টাইল করার জন্য লক্ষ্য করে। আপনি পিতামাতার আকারের জন্য অনুসন্ধান করে সত্যিকারের উপাদান-ভিত্তিক প্রতিক্রিয়াশীল নকশা তৈরি করতে পারেন। এটি মিডিয়া কোয়েরির মতো কিছুর চেয়ে অনেক বেশি দানাদার এবং দরকারী তথ্য যা শুধুমাত্র ভিউপোর্ট সম্পর্কে আকারের তথ্য প্রদান করে।
কন্টেইনার কোয়েরিগুলির সাহায্যে, আপনি পুনঃব্যবহারযোগ্য উপাদানগুলি লিখতে পারেন যা পৃষ্ঠায় কোথায় থাকে তার উপর ভিত্তি করে ভিন্নভাবে প্রদর্শিত হতে পারে। এটি পৃষ্ঠা এবং টেমপ্লেট জুড়ে তাদের অনেক বেশি স্থিতিস্থাপক এবং প্রতিক্রিয়াশীল করে তোলে।
ধারক প্রশ্ন ব্যবহার করে
বলুন আপনার কিছু HTML আছে:
<!-- card parent -->
<div class=”card-parent”>
<div class=”card>
<!-- card contents -->
…
</div>
</div>
একটি কন্টেইনার ক্যোয়ারী ব্যবহার করার জন্য, আপনাকে প্রথমে যে প্যারেন্ট এলিমেন্টটি আপনি ট্র্যাক করতে চান তাতে কনটেইনমেন্ট সেট করতে হবে। container-type
প্রপার্টি সেট করে বা একই সময়ে কন্টেইনারের ধরন এবং কন্টেইনার নাম সেট করতে container
শর্টহ্যান্ড ব্যবহার করে এটি করুন।
.card-parent {
/* query the inline-direction size of this parent */
container-type: inline-size;
}
এখন, আপনি নিকটতম অভিভাবকের উপর ভিত্তি করে শৈলী সেট করতে @container
নিয়ম ব্যবহার করতে পারেন। উপরের চিত্রের মতো একটি নকশার জন্য, যেখানে একটি কার্ড এক কলাম থেকে দুটি কলামে যেতে পারে, এরকম কিছু লিখুন:
@container (min-width: 300px) {
.card {
/* styles to apply when the card container (.card-parent in this case) is >= 300px */
/* I.e. shift from 1-column to 2-column layout: */
grid-template-columns: 1fr 1fr;
}
}
আরও পরিষ্কার এবং স্পষ্ট হতে, মূল উপাদান ধারকটিকে একটি নাম দিন:
.card-parent {
container-type: inline-size;
/* set name here, or write this in one line using the container shorthand */
container-name: card-container;
}
তারপরে পূর্ববর্তী কোডটি আবার লিখুন:
@container card-container (min-width: 300px) {
.card {
grid-template-columns: 1fr 1fr;
}
}
কন্টেইনার কোয়েরি ইউনিট
কন্টেইনার কোয়েরিগুলিকে আরও বেশি উপযোগী করতে, আপনি কন্টেইনার-ভিত্তিক ইউনিট মানগুলিও ব্যবহার করতে পারেন। নিম্নলিখিত সারণীটি সম্ভাব্য কন্টেইনার ইউনিটের মানগুলি দেখায় এবং কীভাবে তারা একটি কন্টেইনারের আকারের সাথে মিলে যায়:
ইউনিট | আপেক্ষিক |
---|---|
cqw | একটি ক্যোয়ারী কন্টেইনারের প্রস্থের 1% |
cqh | একটি ক্যোয়ারী কন্টেইনারের উচ্চতার 1% |
cqi | একটি ক্যোয়ারী কন্টেইনারের ইনলাইন আকারের 1% |
cqb | একটি ক্যোয়ারী কন্টেইনারের ব্লক আকারের 1% |
cqmin | cqi বা cqb এর ছোট মান |
cqmax | cqi বা cqb এর বড় মান |
আপনি কীভাবে কন্টেইনার-ভিত্তিক ইউনিট ব্যবহার করবেন তার একটি উদাহরণ হল প্রতিক্রিয়াশীল টাইপোগ্রাফি। ভিউপোর্ট-ভিত্তিক ইউনিটগুলি (যেমন vh
, vb
, vw
, এবং vi
) স্ক্রিনের যেকোনো উপাদানকে আকার দিতে ব্যবহার করা যেতে পারে।
.card h2 {
font-size: 15cqi;
}
এই কোডটি কন্টেইনারের ইনলাইন আকারের 15% ফন্ট-সাইজকে করে তুলবে, যার অর্থ ইনলাইন আকার (প্রস্থ) বাড়ার সাথে সাথে এটি বড় হবে বা এটি কমার সাথে সাথে ছোট হবে। এটিকে আরও এগিয়ে নিতে, আপনার টাইপোগ্রাফিকে ন্যূনতম এবং সর্বাধিক আকারের সীমা দিতে clamp()
ফাংশনটি ব্যবহার করুন এবং কন্টেইনার আকারের উপর ভিত্তি করে প্রতিক্রিয়াশীলভাবে আকার দিন:
.card h2 {
font-size: clamp(1.5rem, 15cqi, 3rem);
}
এখন শিরোনামটি কখনই 3rem
চেয়ে বড় বা .5rem
থেকে ছোট হবে না তবে এটি কন্টেইনারের ইনলাইন আকারের 15% এর মধ্যে যেকোন জায়গায় নিয়ে যাবে।
এই ডেমোটি এটিকে আরও এক ধাপ এগিয়ে নিয়ে যায় এবং বৃহত্তর কার্ডগুলিকে একটি ছোট আকারের পরিসরের জন্য আপডেট করে, কারণ তারা 2-কলামের ভিউতে উপস্থাপন করে।
কন্টেইনার কোয়েরি পলিফিল
যেহেতু কন্টেইনার কোয়েরিগুলি একটি শক্তিশালী বৈশিষ্ট্য, আমরা চাই আপনি এটিকে আপনার প্রকল্পগুলিতে অন্তর্ভুক্ত করতে স্বাচ্ছন্দ্য বোধ করতে সক্ষম হন এবং জেনে রাখুন যে ব্রাউজার সমর্থন এর একটি বড় অংশ। এই কারণে, আমরা কন্টেইনার কোয়েরি পলিফিল- এ উন্নতি করার জন্য কাজ করছি। এই পলিফিলের মধ্যে সাধারণ সমর্থন রয়েছে:
- ফায়ারফক্স 69+
- Chrome 79+
- প্রান্ত 79+
- Safari 13.4+
কম্প্রেস করার সময় এটির আকার 9kb এর নিচে, এবং বর্তমানে স্থিতিশীল ব্রাউজারে উপলব্ধ সম্পূর্ণ @container ক্যোয়ারী সিনট্যাক্স সমর্থন করতে MutationObserver এর সাথে ResizeObserver ব্যবহার করে:
- বিচ্ছিন্ন প্রশ্ন (
width: 300px
এবংmin-width: 300px
)। - পরিসরের প্রশ্ন (
200px < width < 400px
এবংwidth < 400px
)। - ধারক আপেক্ষিক দৈর্ঘ্য ইউনিট (
cqw
,cqh
,cqi
,cqb
,cqmin
, এবংcqmax
) বৈশিষ্ট্য এবং কীফ্রেমে।
কন্টেইনার ক্যোয়ারী পলিফিল ব্যবহার করে
পলিফিল ব্যবহার করতে, আপনার নথির মাথায় এই স্ক্রিপ্ট ট্যাগ যোগ করুন: :
<script type="module">
if (!("container" in document.documentElement.style)) {
import("https://unpkg.com/container-query-polyfill@^0.2.0");
}
</script>
আপনি শর্তসাপেক্ষে User-Agent
উপর ভিত্তি করে পলিফিল সরবরাহ করার জন্য একটি পরিষেবা ব্যবহার করতে চাইতে পারেন, অথবা আপনার নিজের মূলে এটি স্ব-হোস্ট করতে পারেন।
সর্বোত্তম ব্যবহারকারীর অভিজ্ঞতার জন্য, এটি সুপারিশ করা হয় যে আপনি প্রাথমিকভাবে কেবলমাত্র ভাঁজের নীচের সামগ্রীর জন্য পলিফিল ব্যবহার করুন এবং পলিফিল এটি প্রদর্শনের জন্য প্রস্তুত না হওয়া পর্যন্ত অস্থায়ীভাবে একটি লোডিং সূচক দিয়ে প্রতিস্থাপন করতে @supports
ক্যোয়ারী ব্যবহার করুন:
@supports not (container-type: inline-size) {
.container,
footer {
display: none;
}
.loader {
display: flex;
}
}
পর্যাপ্ত দ্রুত নেটওয়ার্ক এবং ডিভাইস, বা ডিভাইস যা স্থানীয়ভাবে কন্টেইনার প্রশ্ন সমর্থন করে, এই লোডিং সূচকটি কখনই প্রদর্শিত হবে না।
নতুন পলিফিল বৈশিষ্ট্য
আপডেট করা পলিফিল সমর্থন করে:
- নেস্টেড
@container
নিয়ম। -
@supports
এবং@media
প্রশ্নগুলির অধীনে@container
নিয়মগুলি নেস্ট করা এবং এর বিপরীতে সমর্থিত। - শর্তসাপেক্ষ CSS যেমন
@supports (container-type: inline-size)
পলিফিল লোড হওয়ার পরে পাস হবে। - সম্পূর্ণ সিএসএস সিনট্যাক্স সমর্থন (কোনও জায়গায় মন্তব্য রাখার ক্ষেত্রে আর কোনো সমস্যা নেই যে সেগুলি সিনট্যাক্টিকভাবে বৈধ)।
- উল্লম্ব লেখার মোড (লেখা-মোডের মাধ্যমে)।
- কন্টেইনার রিলেটিভ ইউনিট (
cqw
,cqh
, ইত্যাদি) ক্যোয়ারী অবস্থা, সম্পত্তি ঘোষণা এবং অ্যানিমেশন কীফ্রেমের মধ্যে সমর্থিত।rem
এবংem
ক্যোয়ারী অবস্থায় সমর্থিত। - সম্প্রসারিত কন্টেইনার ক্যোয়ারী সিনট্যাক্স:
- রেঞ্জ সিনট্যাক্স (উদাহরণস্বরূপ
(200px < width < 400px)
)। - সমতা প্রশ্ন (উদাহরণস্বরূপ,
(width = 200px)
)।
- রেঞ্জ সিনট্যাক্স (উদাহরণস্বরূপ
- ছদ্ম উপাদান যেমন
::before
এবং::after
। -
:is(...)
/:where(...)
ছাড়া ব্রাউজার একটি ঐচ্ছিক সমাধানের মাধ্যমে সমর্থিত -
orientation
এবংaspect-ratio
বৈশিষ্ট্য প্রশ্ন. - বৈশিষ্ট্যগুলির উপর ভিত্তি করে সঠিকভাবে প্রশ্নগুলি ফিল্টার করা (উদাহরণস্বরূপ, কন্টেইনারে
height
জিজ্ঞাসা করাcontainer: inline-size
সঠিকভাবে অননুমোদিত)৷ - DOM মিউটেশন (উদাহরণস্বরূপ,
<style>
এবং<link>
উপাদানগুলি রানটাইমে সরানো হচ্ছে)।
পলিফিল সীমাবদ্ধতা এবং সতর্কতা
আপনি যদি কন্টেইনার ক্যোয়ারী পলিফিল ব্যবহার করেন, তবে লক্ষ্য রাখতে কিছু অনুপস্থিত বৈশিষ্ট্য রয়েছে:
- ছায়া DOM এখনও সমর্থিত নয়।
- কন্টেইনার রিলেটিভ ইউনিট (উদাহরণস্বরূপ,
cqw
এবংcqh
)@media
ক্যোয়ারী শর্তে সমর্থিত নয়।- সাফারি: 15.4-এর আগে অ্যানিমেশন কীফ্রেমে কনটেইনার রিলেটিভ ইউনিট সমর্থিত নয়।
-
calc()
,min()
,max()
, বা অন্যান্য গাণিতিক ফাংশনগুলি এখনও ক্যোয়ারী অবস্থায় সমর্থিত নয়৷ - এই পলিফিল শুধুমাত্র ইনলাইন এবং একই-অরিজিন CSS এর সাথে কাজ করে। ক্রস অরিজিন স্টাইলশীট, এবং আইফ্রেমের স্টাইলশীট (যদি না একটি পলিফিল ম্যানুয়ালি লোড করা হয়) সমর্থিত নয়।
-
layout
এবংstyle
কন্টেনমেন্ট অন্তর্নিহিত ব্রাউজার সমর্থন প্রয়োজন:- Safari 15.4+
- ফায়ারফক্স এই সময়ে স্টাইল কন্টেনমেন্ট সমর্থন করে না, তবে এটিতে কাজ করছে।
সতর্কতা
- FID এবং CLS-কে প্রভাবিত না করতে, পলিফিল প্রথম লেআউটটি কখন ঘটবে সে সম্পর্কে কোনও গ্যারান্টি দেয় না, এমনকি যদি এটি সিঙ্ক্রোনাসভাবে লোড করা হয়, তবে এটি অযৌক্তিকভাবে এলসিপি বিলম্ব এড়াতে চেষ্টা করবে। অন্য কথায়, প্রথম পেইন্টের জন্য আপনার কখনই এটির উপর নির্ভর করা উচিত নয়।
-
ResizeObserver Loop Errors
তৈরি করে। আসল পলিফিল এটিও করে, তবে এটি কল করার মতো। এটি ঘটে কারণ একটিcontainer-type: inline-size
সম্ভবত একটি প্রশ্নের মূল্যায়ন করার পরে পরিবর্তিত হবে, কিন্তুResizeObserver
এটি বলার কোন উপায় নেই যে আমরা ব্লক-আকার পরিবর্তনের বিষয়ে চিন্তা করি না। - এই পলিফিলটি ওয়েব প্ল্যাটফর্ম টেস্টের বিরুদ্ধে পরীক্ষা করা হয়েছে এবং 70% পাস করেছে কারণ JavaScript API-এর মতো নির্দিষ্ট বৈশিষ্ট্যগুলি পলিফিল করা হয়নি, এবং তাই পাসের হার ইচ্ছাকৃতভাবে 70% এর কাছাকাছি।
- এর থেকে পুরানো ব্রাউজারগুলির 2.23% ব্যবহারকারীদের জন্য :
:where()
সমাধান প্রয়োজন:- সাফারি 14
- ক্রোমিয়াম 88
- প্রান্ত 88
- স্যামসাং ইন্টারনেট 15
- ফায়ারফক্স 78