সিএসএস পডকাস্ট - 015: সিউডো-ক্লাস
বলুন আপনি একটি ইমেল সাইন আপ ফর্ম পেয়েছেন, এবং আপনি চান যে ইমেল ফর্ম ফিল্ডে একটি লাল বর্ডার থাকবে যদি এটি একটি অবৈধ ইমেল ঠিকানা থাকে৷ আপনি এটা কিভাবে করবেন? আপনি একটি :invalid
CSS সিউডো-ক্লাস ব্যবহার করতে পারেন, যা অনেক ব্রাউজার-প্রদত্ত ছদ্ম-শ্রেণীর মধ্যে একটি।
একটি ছদ্ম-শ্রেণী আপনাকে রাষ্ট্র পরিবর্তন এবং বাহ্যিক কারণের উপর ভিত্তি করে শৈলী প্রয়োগ করতে দেয়। এর মানে হল যে আপনার ডিজাইন ব্যবহারকারীর ইনপুট যেমন একটি অবৈধ ইমেল ঠিকানায় প্রতিক্রিয়া জানাতে পারে। এগুলি নির্বাচক মডিউলে আচ্ছাদিত, এবং এই মডিউলটি আপনাকে আরও বিশদে নিয়ে যাবে।
ছদ্ম-উপাদানগুলির বিপরীতে, যেগুলি সম্পর্কে আপনি পূর্ববর্তী মডিউলে আরও শিখতে পারেন, ছদ্ম- শ্রেণীগুলি সেই উপাদানটির সাধারণভাবে স্টাইল অংশগুলির পরিবর্তে একটি নির্দিষ্ট অবস্থার মধ্যে থাকতে পারে।
ইন্টারেক্টিভ রাষ্ট্র
আপনার পৃষ্ঠার সাথে একজন ব্যবহারকারীর ইন্টারঅ্যাকশনের কারণে নিম্নলিখিত ছদ্ম-শ্রেণীগুলি প্রযোজ্য।
:hover
যদি একজন ব্যবহারকারীর কাছে মাউস বা ট্র্যাকপ্যাডের মতো একটি পয়েন্টিং ডিভাইস থাকে এবং তারা এটিকে একটি উপাদানের উপর রাখে, তাহলে আপনি শৈলী প্রয়োগ করতে :hover
দিয়ে সেই অবস্থায় হুক করতে পারেন। এটি ইঙ্গিত দেওয়ার একটি কার্যকর উপায় যে একটি উপাদানের সাথে ইন্টারঅ্যাক্ট করা যেতে পারে।
:active
এই অবস্থাটি ট্রিগার হয় যখন একটি উপাদানের সাথে সক্রিয়ভাবে ইন্টারঅ্যাক্ট করা হয়—যেমন একটি ক্লিক—ক্লিক প্রকাশের আগে। যদি একটি মাউসের মতো একটি নির্দেশক যন্ত্র ব্যবহার করা হয়, এই অবস্থা তখন যখন ক্লিক শুরু হয় এবং এখনও প্রকাশিত হয়নি।
:focus
, :focus-within
, এবং :focus-visible
যদি একটি উপাদান ফোকাস গ্রহণ করতে পারে - যেমন একটি <button>
- তাহলে আপনি :focus
সিউডো-ক্লাসের সাথে সেই অবস্থায় প্রতিক্রিয়া জানাতে পারেন।
আপনার উপাদানের একটি শিশু উপাদান যদি :focus-within
দিয়ে ফোকাস পায় তাহলেও আপনি প্রতিক্রিয়া জানাতে পারেন।
ফোকাসযোগ্য উপাদান, বোতামগুলির মতো, ফোকাস রিং দেখাবে যখন সেগুলি ফোকাসে থাকে—এমনকি ক্লিক করার পরেও৷ এই ধরণের পরিস্থিতিতে, একজন বিকাশকারী নিম্নলিখিত CSS প্রয়োগ করবে:
button:focus {
outline: none;
}
এই CSS ডিফল্ট ব্রাউজার ফোকাস রিং সরিয়ে দেয় যখন একটি উপাদান ফোকাস পায়, যা ব্যবহারকারীদের জন্য একটি অ্যাক্সেসিবিলিটি সমস্যা উপস্থাপন করে যারা একটি কীবোর্ড দিয়ে একটি ওয়েব পৃষ্ঠা নেভিগেট করে। যদি কোন ফোকাস শৈলী না থাকে, তাহলে ট্যাব কী ব্যবহার করার সময় তারা বর্তমানে কোথায় ফোকাস আছে তার ট্র্যাক রাখতে সক্ষম হবে না। সঙ্গে :focus-visible
আপনি একটি ফোকাস শৈলী উপস্থাপন করতে পারেন যখন একটি উপাদান কীবোর্ডের মাধ্যমে ফোকাস গ্রহণ করে, পাশাপাশি outline: none
নিয়ম নেই।
button:focus {
outline: none;
}
button:focus-visible {
outline: 1px solid black;
}
:target
:target
pseudo-class এমন একটি উপাদান নির্বাচন করে যার একটি URL খণ্ডের সাথে মিলে যাওয়া একটি id
রয়েছে৷ বলুন আপনার কাছে নিম্নলিখিত HTML আছে:
<article id="content">
…
</article>
url-এ #content
থাকলে আপনি সেই উপাদানটির সাথে শৈলী সংযুক্ত করতে পারেন।
#content:target {
background: yellow;
}
এটি বিশেষভাবে লিঙ্ক করা হয়েছে এমন এলাকাগুলি হাইলাইট করার জন্য দরকারী, যেমন একটি ওয়েবসাইটের প্রধান বিষয়বস্তু, একটি স্কিপ লিঙ্কের মাধ্যমে৷
ঐতিহাসিক রাষ্ট্র
:link
:link
pseudo-class যেকোন <a>
উপাদানে প্রয়োগ করা যেতে পারে যার একটি href
মান রয়েছে যা এখনও পরিদর্শন করা হয়নি ।
:visited
আপনি একটি লিঙ্ক স্টাইল করতে পারেন যা ব্যবহারকারীরা ইতিমধ্যেই পরিদর্শন করেছেন :visited
pseudo-class ব্যবহার করে। এটি :link
এর বিপরীত অবস্থা কিন্তু নিরাপত্তার কারণে ব্যবহার করার জন্য আপনার কাছে কম CSS বৈশিষ্ট্য রয়েছে। আপনি শুধুমাত্র color
, background-color
, border-color
, outline-color
এবং SVG fill
এবং stroke
রঙ স্টাইল করতে পারেন।
অর্ডার বিষয়
যদি আপনি একটি :visited
শৈলী সংজ্ঞায়িত করেন, তবে এটি অন্তত সমান নির্দিষ্টতার সাথে একটি লিঙ্ক সিউডো-ক্লাস দ্বারা ওভাররাইড করা যেতে পারে। এই কারণে, এটি সুপারিশ করা হচ্ছে যে আপনি একটি নির্দিষ্ট ক্রমে ছদ্ম-শ্রেণীর সাথে লিঙ্কগুলিকে স্টাইলিং করার জন্য LVHA নিয়মটি ব্যবহার করুন: :link
, :visited
, :hover
, :active
।
a:link {}
a:visited {}
a:hover {}
a:active {}
ফর্ম রাজ্য
নিম্নলিখিত ছদ্ম-শ্রেণীগুলি ফর্ম উপাদানগুলি নির্বাচন করতে পারে, বিভিন্ন রাজ্যে এই উপাদানগুলি তাদের সাথে মিথস্ক্রিয়া করার সময় থাকতে পারে।
:disabled
এবং :enabled
যদি একটি ফর্ম উপাদান, যেমন একটি <button>
ব্রাউজার দ্বারা নিষ্ক্রিয় করা হয়, তাহলে আপনি :disabled
pseudo-class দিয়ে সেই অবস্থার সাথে যুক্ত হতে পারেন। :enabled
ছদ্ম-শ্রেণি বিপরীত অবস্থার জন্য উপলব্ধ, যদিও ফর্ম উপাদানগুলিও ডিফল্টরূপে :enabled
থাকে, তাই আপনি এই ছদ্ম-শ্রেণীর জন্য পৌঁছানোর জন্য নিজেকে খুঁজে পাবেন না।
:checked
এবং :indeterminate
একটি সমর্থনকারী ফর্ম উপাদান, যেমন একটি চেকবক্স বা রেডিও বোতাম চেক করা অবস্থায় থাকলে : :checked
ছদ্ম-শ্রেণি পাওয়া যায়।
:checked
স্টেট হল একটি বাইনারি (সত্য বা মিথ্যা) অবস্থা, কিন্তু চেকবক্সের মধ্যে একটি ইন-বিটুইন স্টেট থাকে যখন সেগুলি চেক করা বা আনচেক করা হয় না। এটিকে বলা হয় :indeterminate
অবস্থা।
এই অবস্থার একটি উদাহরণ হল যখন আপনার একটি "সব নির্বাচন করুন" নিয়ন্ত্রণ থাকে যা একটি গ্রুপের সমস্ত চেকবক্স চেক করে। ব্যবহারকারী যদি এই চেকবক্সগুলির মধ্যে একটির টিক চিহ্ন মুক্ত করতে চান, তাহলে রুট চেকবক্সটি আর "সমস্ত" চেক করা প্রতিনিধিত্ব করবে না, তাই একটি অনির্দিষ্ট অবস্থায় রাখা উচিত।
<progress>
উপাদানটিরও একটি অনির্দিষ্ট অবস্থা রয়েছে যা স্টাইল করা যেতে পারে। একটি সাধারণ ব্যবহারের ক্ষেত্রে এটিকে একটি ডোরাকাটা চেহারা দেওয়া হয় যাতে আরও কতটা প্রয়োজন তা অজানা।
:placeholder-shown
যদি একটি ফর্ম ক্ষেত্রের একটি placeholder
বৈশিষ্ট্য থাকে এবং কোনো মান না থাকে , তাহলে :placeholder-shown
ছদ্ম-শ্রেণীটি সেই অবস্থায় শৈলী সংযুক্ত করতে ব্যবহার করা যেতে পারে। যত তাড়াতাড়ি ক্ষেত্র বিষয়বস্তু আছে, এটি একটি placeholder
আছে কি না, এই রাষ্ট্র আর প্রযোজ্য হবে না.
বৈধতা রাষ্ট্র
আপনি ছদ্ম-শ্রেণি যেমন :valid
, :invalid
এবং :in-range
দিয়ে HTML ফর্ম যাচাইকরণে সাড়া দিতে পারেন। :valid
এবং :invalid
ছদ্ম-শ্রেণিগুলি প্রসঙ্গগুলির জন্য দরকারী যেমন একটি ইমেল ক্ষেত্র যাতে একটি pattern
আছে যা মিলিত হওয়া প্রয়োজন, এটি একটি বৈধ ক্ষেত্র হওয়ার জন্য৷ এই বৈধ মান অবস্থা ব্যবহারকারীকে দেখানো যেতে পারে, তাদের বুঝতে সাহায্য করে যে তারা নিরাপদে পরবর্তী ক্ষেত্রে যেতে পারে।
:in-range
সিউডো-ক্লাস পাওয়া যায় যদি একটি ইনপুটে একটি min
এবং max
থাকে, যেমন একটি সাংখ্যিক ইনপুট এবং মানটি সেই সীমার মধ্যে থাকে।
HTML ফর্মের সাহায্যে, আপনি নির্ধারণ করতে পারেন যে required
বৈশিষ্ট্য সহ একটি ক্ষেত্র প্রয়োজন। প্রয়োজনীয় ক্ষেত্রগুলির জন্য :required
ছদ্ম-শ্রেণী উপলব্ধ হবে। যে ক্ষেত্রগুলির প্রয়োজন নেই সেগুলিকে :optional
pseudo-class দিয়ে নির্বাচন করা যেতে পারে।
তাদের সূচক, ক্রম এবং ঘটনা দ্বারা উপাদান নির্বাচন করা
সিউডো-ক্লাসের একটি গ্রুপ রয়েছে যেগুলি নথিতে কোথায় রয়েছে তার উপর ভিত্তি করে আইটেমগুলি নির্বাচন করে।
:first-child
এবং :last-child
আপনি যদি প্রথম বা শেষ আইটেমটি খুঁজে পেতে চান তবে আপনি :first-child
এবং :last-child
ব্যবহার করতে পারেন। এই সিউডো-ক্লাসগুলি ভাইবোন উপাদানগুলির একটি গ্রুপের প্রথম বা শেষ উপাদানটি ফিরিয়ে দেবে।
:only-child
আপনি :only-child
pseudo-class সহ এমন উপাদান নির্বাচন করতে পারেন যার কোনো ভাইবোন নেই।
:first-of-type
এবং :last-of-type
আপনি :first-of-type
এবং :last-of-type
নির্বাচন করতে পারেন যা প্রথমে দেখে মনে হবে তারা একই কাজ করে :first-child
এবং :last-child
, কিন্তু এই HTMLটি বিবেচনা করুন:
<div class="my-parent">
<p>A paragraph</p>
<div>A div</div>
<div>Another div</div>
</div>
এবং এই CSS:
.my-parent div:first-child {
color: red;
}
কোনো উপাদান লাল রঙের হবে না কারণ প্রথম সন্তানটি একটি অনুচ্ছেদ এবং একটি ডিভ নয়। এই প্রসঙ্গে :first-of-type
pseudo-class উপযোগী।
.my-parent div:first-of-type {
color: red;
}
যদিও প্রথম <div>
দ্বিতীয় সন্তান, তবুও এটি .my-parent
এলিমেন্টের মধ্যে টাইপের প্রথম, তাই এই নিয়মের সাথে, এটি লাল রঙের হবে।
:nth-child
এবং :nth-of-type
আপনি প্রথম এবং শেষ শিশু এবং প্রকারের মধ্যে সীমাবদ্ধ নন। :nth-child
এবং :nth-of-type
ছদ্ম-শ্রেণীগুলি আপনাকে একটি উপাদান নির্দিষ্ট করতে দেয় যা একটি নির্দিষ্ট সূচকে থাকে। CSS নির্বাচকদের মধ্যে সূচীকরণ 1 থেকে শুরু হয়।
আপনি এই ছদ্ম-শ্রেণীতেও একটি সূচকের চেয়ে বেশি পাস করতে পারেন। আপনি যদি সমস্ত জোড় উপাদান নির্বাচন করতে চান তবে আপনি :nth-child(even)
ব্যবহার করতে পারেন।
এছাড়াও আপনি আরও জটিল নির্বাচক তৈরি করতে পারেন যা An+B মাইক্রোসিনট্যাক্স ব্যবহার করে নিয়মিত ব্যবধানে আইটেমগুলি খুঁজে পায়।
li:nth-child(3n+3) {
background: yellow;
}
এই নির্বাচক প্রতিটি তৃতীয় আইটেম নির্বাচন করে, আইটেম 3 থেকে শুরু করে। এই এক্সপ্রেশনের n
হল সূচী, যা শূন্য থেকে শুরু হয় 3 ( 3n
) আপনি সেই সূচকটিকে কত দিয়ে গুণ করেন।
ধরা যাক আপনার 7 টি <li>
আইটেম আছে। নির্বাচিত প্রথম আইটেমটি হল 3 কারণ 3n+3
অনুবাদ করে (3 * 0) + 3
। পরবর্তী পুনরাবৃত্তি আইটেম 6 বাছাই করবে কারণ n
এখন 1
এ বৃদ্ধি পেয়েছে, তাই (3 * 1) + 3)
। এই অভিব্যক্তিটি :nth-child
এবং :nth-of-type
উভয়ের জন্যই কাজ করে।
আপনি এই nth-শিশু পরীক্ষক বা এই পরিমাণ নির্বাচক টুলে এই ধরণের নির্বাচকের সাথে খেলতে পারেন।
:only-of-type
সবশেষে, আপনি ভাইবোনদের একটি গোষ্ঠীতে একটি নির্দিষ্ট ধরণের একমাত্র উপাদান খুঁজে পেতে পারেন :only-of-type
এর সাথে। আপনি যদি শুধুমাত্র একটি আইটেম সহ তালিকা নির্বাচন করতে চান বা আপনি যদি একটি অনুচ্ছেদে একমাত্র সাহসী উপাদান খুঁজে পেতে চান তবে এটি কার্যকর।
খালি উপাদান খোঁজা
এটি কখনও কখনও সম্পূর্ণ খালি উপাদানগুলি সনাক্ত করতে কার্যকর হতে পারে এবং এটির জন্যও একটি ছদ্ম-শ্রেণী রয়েছে।
:empty
যদি কোনো উপাদানের কোনো সন্তান না থাকে, তাহলে :empty
ছদ্ম-শ্রেণী তাদের ক্ষেত্রে প্রযোজ্য। যদিও বাচ্চারা শুধুমাত্র HTML উপাদান বা টেক্সট নোড নয়: এগুলি হোয়াইটস্পেসও হতে পারে, যা আপনি যখন নিম্নলিখিত HTML ডিবাগ করছেন এবং ভাবছেন কেন এটি :empty
এর সাথে কাজ করছে না তখন বিভ্রান্তিকর হতে পারে।
<div>
</div>
কারণ হল খোলার এবং বন্ধ করার মধ্যে কিছু হোয়াইটস্পেস আছে <div>
, তাই খালি কাজ করবে না।
আপনার যদি HTML-এর উপর সামান্য নিয়ন্ত্রণ থাকে এবং WYSIWYG বিষয়বস্তু সম্পাদকের মতো খালি উপাদানগুলিকে আড়াল করতে চান তাহলে :empty
pseudo-class কার্যকর হতে পারে। এখানে, একজন সম্পাদক একটি বিপথগামী, খালি অনুচ্ছেদ যোগ করেছেন।
<article class="post">
<p>Donec ullamcorper nulla non metus auctor fringilla.</p>
<p></p>
<p>Curabitur blandit tempus porttitor.</p>
</article>
:empty
দিয়ে, আপনি এটি খুঁজে পেতে এবং লুকাতে পারেন।
.post :empty {
display: none;
}
একাধিক উপাদান খুঁজে বের করা এবং বাদ দেওয়া
কিছু সিউডো-ক্লাস আপনাকে আরও কমপ্যাক্ট CSS লিখতে সাহায্য করে।
:is()
আপনি যদি .post
এলিমেন্টে h2
, li
এবং img
চাইল্ড এলিমেন্টের সবগুলো খুঁজে পেতে চান, তাহলে আপনি এইরকম একটি নির্বাচক তালিকা লিখতে পারেন:
.post h2,
.post li,
.post img {
…
}
:is()
ছদ্ম-শ্রেণীর সাথে, আপনি আরও কমপ্যাক্ট সংস্করণ লিখতে পারেন:
.post :is(h2, li, img) {
…
}
:is
ছদ্ম-শ্রেণি শুধুমাত্র একটি নির্বাচক তালিকার চেয়ে বেশি কম্প্যাক্ট নয় বরং এটি আরও ক্ষমাশীল। বেশিরভাগ ক্ষেত্রে, যদি একটি নির্বাচক তালিকায় একটি ত্রুটি বা অসমর্থিত নির্বাচক থাকে, তাহলে সম্পূর্ণ নির্বাচক তালিকা আর কাজ করবে না। যদি একটি :is
ছদ্ম-শ্রেণিতে পাস করা নির্বাচকদের মধ্যে কোনো ত্রুটি থাকে, তাহলে এটি অবৈধ নির্বাচককে উপেক্ষা করবে, কিন্তু যেগুলি বৈধ সেগুলি ব্যবহার করবে৷
:not()
আপনি :not()
pseudo-class দিয়ে আইটেমগুলিকে বাদ দিতে পারেন। উদাহরণস্বরূপ, আপনি এটি ব্যবহার করতে পারেন এমন সমস্ত লিঙ্ক স্টাইল করার জন্য যেগুলির কোনও class
অ্যাট্রিবিউট নেই৷
a:not([class]) {
color: blue;
}
A :not
সিউডো-ক্লাস আপনাকে অ্যাক্সেসযোগ্যতা উন্নত করতে সাহায্য করতে পারে। উদাহরণস্বরূপ, একটি <img>
একটি alt
থাকতে হবে, এমনকি এটি একটি খালি মান হলেও, তাই আপনি একটি CSS নিয়ম লিখতে পারেন যা অবৈধ চিত্রগুলিতে একটি মোটা লাল রূপরেখা যোগ করে:
img:not([alt]) {
outline: 10px red;
}
আপনার উপলব্ধি পরীক্ষা করুন
ছদ্ম ক্লাস আপনার জ্ঞান পরীক্ষা
সিউডো-ক্লাসগুলি এমনভাবে কাজ করে যেন একটি ক্লাস একটি উপাদানের উপর গতিশীলভাবে প্রয়োগ করা হয়েছে, যখন ছদ্ম-উপাদানগুলি একটি উপাদানের উপর কাজ করে।
নিচের কোনটি কার্যকরী সিউডো-শ্রেণী?
:not()
:is()
:target
:empty
নিম্নলিখিত কোন ছদ্ম-শ্রেণি একটি ব্যবহারকারী-মিথস্ক্রিয়া কারণে হয়?
:squeeze
:hover
:focus-within
:target
:press
নিচের কোনটি <form>
স্টেট সিউডো ক্লাস?
:loading
:valid
:checked
:enabled
:in-range
:indeterminate
:fresh