ছদ্ম-শ্রেণী

সিএসএস পডকাস্ট - 015: সিউডো-ক্লাস

বলুন আপনি একটি ইমেল সাইন আপ ফর্ম পেয়েছেন, এবং আপনি চান যে ইমেল ফর্ম ফিল্ডে একটি লাল বর্ডার থাকবে যদি এটি একটি অবৈধ ইমেল ঠিকানা থাকে৷ তুমি এটা কিভাবে করলে? আপনি একটি :invalid CSS সিউডো-ক্লাস ব্যবহার করতে পারেন, যা অনেক ব্রাউজার-প্রদত্ত ছদ্ম-শ্রেণীর মধ্যে একটি।

একটি ছদ্ম-শ্রেণী আপনাকে রাষ্ট্র পরিবর্তন এবং বাহ্যিক কারণের উপর ভিত্তি করে শৈলী প্রয়োগ করতে দেয়। এর মানে হল যে আপনার ডিজাইন ব্যবহারকারীর ইনপুট যেমন একটি অবৈধ ইমেল ঠিকানায় প্রতিক্রিয়া জানাতে পারে। এগুলি নির্বাচক মডিউলে আচ্ছাদিত, এবং এই মডিউলটি আপনাকে আরও বিশদে নিয়ে যাবে।

ছদ্ম-উপাদানগুলির বিপরীতে, যেগুলি সম্পর্কে আপনি পূর্ববর্তী মডিউলে আরও শিখতে পারেন, ছদ্ম- শ্রেণীগুলি সেই উপাদানটির সাধারণভাবে স্টাইল অংশগুলির পরিবর্তে একটি নির্দিষ্ট অবস্থার মধ্যে থাকতে পারে।

ইন্টারেক্টিভ রাষ্ট্র

আপনার পৃষ্ঠার সাথে একজন ব্যবহারকারীর ইন্টারঅ্যাকশনের কারণে নিম্নলিখিত ছদ্ম-শ্রেণীগুলি প্রযোজ্য।

:hover

ব্রাউজার সমর্থন

  • 1
  • 12
  • 1
  • 2

উৎস

যদি একজন ব্যবহারকারীর কাছে মাউস বা ট্র্যাকপ্যাডের মতো একটি পয়েন্টিং ডিভাইস থাকে এবং তারা এটিকে একটি উপাদানের উপর রাখে, তাহলে আপনি শৈলী প্রয়োগ করতে :hover দিয়ে সেই অবস্থায় হুক করতে পারেন। এটি ইঙ্গিত দেওয়ার একটি কার্যকর উপায় যে একটি উপাদানের সাথে ইন্টারঅ্যাক্ট করা যেতে পারে।

:active

ব্রাউজার সমর্থন

  • 1
  • 12
  • 1
  • 1

উৎস

এই অবস্থাটি ট্রিগার হয় যখন একটি উপাদানের সাথে সক্রিয়ভাবে ইন্টারঅ্যাক্ট করা হয়—যেমন একটি ক্লিক—ক্লিক প্রকাশের আগে। যদি একটি মাউসের মতো একটি নির্দেশক যন্ত্র ব্যবহার করা হয়, এই অবস্থা তখন যখন ক্লিক শুরু হয় এবং এখনও প্রকাশিত হয়নি।

:focus , :focus-within , এবং :focus-visible

ব্রাউজার সমর্থন

  • 1
  • 12
  • 1
  • 1

উৎস

যদি একটি উপাদান ফোকাস গ্রহণ করতে পারে - যেমন একটি <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

ব্রাউজার সমর্থন

  • 1
  • 12
  • 1
  • 1.3

উৎস

:target pseudo-class এমন একটি উপাদান নির্বাচন করে যার একটি URL খণ্ডের সাথে মিলে যাওয়া একটি id রয়েছে৷ বলুন আপনার কাছে নিম্নলিখিত HTML আছে:

<article id="content">
    …
</article>

url-এ #content থাকলে আপনি সেই উপাদানটির সাথে শৈলী সংযুক্ত করতে পারেন।

#content:target {
    background: yellow;
}

এটি বিশেষভাবে লিঙ্ক করা হয়েছে এমন এলাকাগুলি হাইলাইট করার জন্য দরকারী, যেমন একটি ওয়েবসাইটের প্রধান বিষয়বস্তু, একটি স্কিপ লিঙ্কের মাধ্যমে৷

ঐতিহাসিক রাষ্ট্র

ব্রাউজার সমর্থন

  • 1
  • 12
  • 1
  • 1

উৎস

: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

ব্রাউজার সমর্থন

  • 1
  • 12
  • 1
  • 3.1

উৎস

যদি একটি ফর্ম উপাদান, যেমন একটি <button> ব্রাউজার দ্বারা নিষ্ক্রিয় করা হয়, তাহলে আপনি :disabled pseudo-class দিয়ে সেই অবস্থার সাথে যুক্ত হতে পারেন। :enabled ছদ্ম-শ্রেণি বিপরীত অবস্থার জন্য উপলব্ধ, যদিও ফর্ম উপাদানগুলিও ডিফল্টরূপে :enabled থাকে, তাই আপনি নিজেকে এই ছদ্ম-শ্রেণীর জন্য পৌঁছাতে নাও পেতে পারেন।

:checked এবং :indeterminate

ব্রাউজার সমর্থন

  • 1
  • 12
  • 1
  • 3.1

উৎস

একটি সমর্থনকারী ফর্ম উপাদান, যেমন একটি চেকবক্স বা রেডিও বোতাম চেক করা অবস্থায় থাকলে : :checked ছদ্ম-শ্রেণি পাওয়া যায়।

:checked স্টেট হল একটি বাইনারি (সত্য বা মিথ্যা) অবস্থা, কিন্তু চেকবক্সের মধ্যে একটি ইন-বিটুইন স্টেট থাকে যখন সেগুলি চেক করা বা আনচেক করা হয় না। এটিকে বলা হয় :indeterminate অবস্থা।

এই অবস্থার একটি উদাহরণ হল যখন আপনার একটি "সব নির্বাচন করুন" নিয়ন্ত্রণ থাকে যা একটি গ্রুপের সমস্ত চেকবক্স চেক করে। ব্যবহারকারী যদি এই চেকবক্সগুলির মধ্যে একটির টিক চিহ্ন মুক্ত করতে চান, তাহলে রুট চেকবক্সটি আর "সমস্ত" চেক করা প্রতিনিধিত্ব করবে না, তাই একটি অনির্দিষ্ট অবস্থায় রাখা উচিত।

<progress> উপাদানটিরও একটি অনির্দিষ্ট অবস্থা রয়েছে যা স্টাইল করা যেতে পারে। একটি সাধারণ ব্যবহারের ক্ষেত্রে এটিকে একটি ডোরাকাটা চেহারা দেওয়া হয় যাতে আরও কতটা প্রয়োজন তা অজানা।

:placeholder-shown

ব্রাউজার সমর্থন

  • 47
  • 79
  • 51
  • 9

উৎস

যদি একটি ফর্ম ক্ষেত্রের একটি placeholder বৈশিষ্ট্য থাকে এবং কোনো মান না থাকে, তাহলে :placeholder-shown ছদ্ম-শ্রেণীটি সেই অবস্থায় শৈলী সংযুক্ত করতে ব্যবহার করা যেতে পারে। যত তাড়াতাড়ি ক্ষেত্র বিষয়বস্তু আছে, এটি একটি placeholder আছে কি না, এই রাষ্ট্র আর প্রযোজ্য হবে না.

বৈধতা রাষ্ট্র

ব্রাউজার সমর্থন

  • 10
  • 12
  • 4
  • 5

উৎস

আপনি ছদ্ম-শ্রেণি যেমন :valid , :invalid এবং :in-range দিয়ে HTML ফর্ম যাচাইকরণে সাড়া দিতে পারেন। :valid এবং :invalid ছদ্ম-শ্রেণিগুলি প্রসঙ্গগুলির জন্য দরকারী যেমন একটি ইমেল ক্ষেত্র যাতে একটি pattern আছে যা মিলিত হওয়া প্রয়োজন, এটি একটি বৈধ ক্ষেত্র হওয়ার জন্য৷ এই বৈধ মান অবস্থা ব্যবহারকারীকে দেখানো যেতে পারে, তাদের বুঝতে সাহায্য করে যে তারা নিরাপদে পরবর্তী ক্ষেত্রে যেতে পারে।

:in-range সিউডো-ক্লাস পাওয়া যায় যদি একটি ইনপুটে একটি min এবং max থাকে, যেমন একটি সাংখ্যিক ইনপুট এবং মানটি সেই সীমার মধ্যে থাকে।

HTML ফর্মের সাহায্যে, আপনি নির্ধারণ করতে পারেন যে required বৈশিষ্ট্য সহ একটি ক্ষেত্র প্রয়োজন। প্রয়োজনীয় ক্ষেত্রগুলির জন্য :required ছদ্ম-শ্রেণী উপলব্ধ হবে। যে ক্ষেত্রগুলির প্রয়োজন নেই সেগুলিকে :optional pseudo-class দিয়ে নির্বাচন করা যেতে পারে।

তাদের সূচক, ক্রম এবং ঘটনা দ্বারা উপাদান নির্বাচন করা

সিউডো-ক্লাসের একটি গ্রুপ রয়েছে যেগুলি নথিতে কোথায় রয়েছে তার উপর ভিত্তি করে আইটেমগুলি নির্বাচন করে।

:first-child এবং :last-child

ব্রাউজার সমর্থন

  • 4
  • 12
  • 3
  • 3.1

উৎস

আপনি যদি প্রথম বা শেষ আইটেমটি খুঁজে পেতে চান তবে আপনি :first-child এবং :last-child ব্যবহার করতে পারেন। এই সিউডো-ক্লাসগুলি ভাইবোন উপাদানগুলির একটি গ্রুপের প্রথম বা শেষ উপাদানটি ফিরিয়ে দেবে।

:only-child

ব্রাউজার সমর্থন

  • 2
  • 12
  • 1.5
  • 3.1

উৎস

আপনি :only-child pseudo-class সহ এমন উপাদান নির্বাচন করতে পারেন যার কোনো ভাইবোন নেই।

:first-of-type এবং :last-of-type

ব্রাউজার সমর্থন

  • 1
  • 12
  • 3.5
  • 3.1

উৎস

আপনি :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

ব্রাউজার সমর্থন

  • 1
  • 12
  • 3.5
  • 3.1

উৎস

আপনি প্রথম এবং শেষ শিশু এবং প্রকারের মধ্যে সীমাবদ্ধ নন। :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

ব্রাউজার সমর্থন

  • 1
  • 12
  • 3.5
  • 3.1

উৎস

সবশেষে, আপনি ভাইবোনদের একটি গোষ্ঠীতে একটি নির্দিষ্ট ধরণের একমাত্র উপাদান খুঁজে পেতে পারেন :only-of-type এর সাথে। আপনি যদি শুধুমাত্র একটি আইটেম সহ তালিকা নির্বাচন করতে চান বা আপনি যদি একটি অনুচ্ছেদে একমাত্র সাহসী উপাদান খুঁজে পেতে চান তবে এটি কার্যকর।

খালি উপাদান খোঁজা

এটি কখনও কখনও সম্পূর্ণ খালি উপাদানগুলি সনাক্ত করতে কার্যকর হতে পারে এবং এটির জন্যও একটি ছদ্ম-শ্রেণী রয়েছে।

:empty

ব্রাউজার সমর্থন

  • 1
  • 12
  • 1
  • 3.1

উৎস

যদি কোনো উপাদানের কোনো সন্তান না থাকে, তাহলে :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()

ব্রাউজার সমর্থন

  • ৮৮
  • ৮৮
  • 78
  • 14

উৎস

আপনি যদি .post এলিমেন্টে h2 , li এবং img চাইল্ড এলিমেন্টের সবগুলো খুঁজে পেতে চান, তাহলে আপনি এইরকম একটি নির্বাচক তালিকা লিখতে পারেন:

.post h2,
.post li,
.post img {
    …
}

:is() ছদ্ম-শ্রেণীর সাথে, আপনি আরও কমপ্যাক্ট সংস্করণ লিখতে পারেন:

.post :is(h2, li, img) {
    …
}

:is ছদ্ম-শ্রেণি শুধুমাত্র একটি নির্বাচক তালিকার চেয়ে বেশি কম্প্যাক্ট নয় বরং এটি আরও ক্ষমাশীল। বেশিরভাগ ক্ষেত্রে, যদি একটি নির্বাচক তালিকায় একটি ত্রুটি বা অসমর্থিত নির্বাচক থাকে, তাহলে সম্পূর্ণ নির্বাচক তালিকা আর কাজ করবে না। যদি একটি :is ছদ্ম-শ্রেণিতে পাস করা নির্বাচকদের মধ্যে কোনো ত্রুটি থাকে, তাহলে এটি অবৈধ নির্বাচককে উপেক্ষা করবে, কিন্তু যেগুলি বৈধ সেগুলি ব্যবহার করবে৷

:not()

ব্রাউজার সমর্থন

  • 1
  • 12
  • 1
  • 3.1

উৎস

আপনি :not() pseudo-class দিয়ে আইটেমগুলিকে বাদ দিতে পারেন। উদাহরণস্বরূপ, আপনি এটি ব্যবহার করতে পারেন এমন সমস্ত লিঙ্ক স্টাইল করার জন্য যেগুলির কোনও class অ্যাট্রিবিউট নেই৷

a:not([class]) {
    color: blue;
}

A :not সিউডো-ক্লাস আপনাকে অ্যাক্সেসযোগ্যতা উন্নত করতে সাহায্য করতে পারে। উদাহরণস্বরূপ, একটি <img> একটি alt থাকতে হবে, এমনকি এটি একটি খালি মান হলেও, তাই আপনি একটি CSS নিয়ম লিখতে পারেন যা অবৈধ চিত্রগুলিতে একটি মোটা লাল রূপরেখা যোগ করে:

img:not([alt]) {
    outline: 10px red;
}

আপনার উপলব্ধি পরীক্ষা করুন

ছদ্ম ক্লাস আপনার জ্ঞান পরীক্ষা

সিউডো-ক্লাসগুলি এমনভাবে কাজ করে যেন একটি ক্লাস একটি উপাদানের উপর গতিশীলভাবে প্রয়োগ করা হয়েছে, যখন ছদ্ম-উপাদানগুলি একটি উপাদানের উপর কাজ করে।

সত্য
একটি একক বা ডবল ব্যবহারের জন্য দেখুন : নির্বাচকের মধ্যে একটি মূল বিশিষ্ট অক্ষর হিসাবে
মিথ্যা
ছদ্ম-উপাদানগুলি অংশগুলির জন্য, ছদ্ম-শ্রেণীগুলি রাষ্ট্রের জন্য।

নিচের কোনটি কার্যকরী সিউডো-শ্রেণী?

:is()
🎉
:target
কার্যকরী ছদ্ম-শ্রেণিগুলির পরে () থাকে, বোঝাতে যে তারা পরামিতিগুলি গ্রহণ করে।
:empty
কার্যকরী ছদ্ম-শ্রেণিগুলির পরে () থাকে, বোঝাতে যে তারা পরামিতিগুলি গ্রহণ করে।
:not()
🎉

নিম্নলিখিত কোন ছদ্ম-শ্রেণি একটি ব্যবহারকারী-মিথস্ক্রিয়া কারণে হয়?

:hover
🎉
:press
আবার চেষ্টা কর!
:squeeze
আবার চেষ্টা কর!
:target
🎉
:focus-within
🎉

নিচের কোনটি <form> স্টেট সিউডো ক্লাস?

:enabled
🎉
:fresh
আবার চেষ্টা কর!
:indeterminate
🎉
:checked
🎉
:in-range
🎉
:loading
আবার চেষ্টা কর!
:valid
🎉