ছদ্ম-শ্রেণী

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

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

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

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

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

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

:hover

Browser Support

  • ক্রোম: ১.
  • প্রান্ত: 12।
  • ফায়ারফক্স: ১.
  • সাফারি: 2।

Source

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

:active

Browser Support

  • ক্রোম: ১.
  • প্রান্ত: 12।
  • ফায়ারফক্স: ১.
  • সাফারি: 1

Source

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

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

Browser Support

  • ক্রোম: ১.
  • প্রান্ত: 12।
  • ফায়ারফক্স: ১.
  • সাফারি: 1

Source

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

Browser Support

  • ক্রোম: ১.
  • প্রান্ত: 12।
  • ফায়ারফক্স: ১.
  • সাফারি: 1.3।

Source

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

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

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

#content:target {
    background: yellow;
}

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

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

Browser Support

  • ক্রোম: ১.
  • প্রান্ত: 12।
  • ফায়ারফক্স: ১.
  • সাফারি: 1

Source

: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

Browser Support

  • ক্রোম: ১.
  • প্রান্ত: 12।
  • ফায়ারফক্স: ১.
  • সাফারি: 3.1।

Source

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

:checked এবং :indeterminate

Browser Support

  • ক্রোম: ১.
  • প্রান্ত: 12।
  • ফায়ারফক্স: ১.
  • সাফারি: 3.1।

Source

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

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

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

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

:placeholder-shown

Browser Support

  • ক্রোম: 47।
  • প্রান্ত: 79।
  • ফায়ারফক্স: 51।
  • সাফারি: 9।

Source

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

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

Browser Support

  • ক্রোম: 10।
  • প্রান্ত: 12।
  • ফায়ারফক্স: 4.
  • সাফারি: 5।

Source

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

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

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

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

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

:first-child এবং :last-child

Browser Support

  • ক্রোম: 4.
  • প্রান্ত: 12।
  • ফায়ারফক্স: 3.
  • সাফারি: 3.1।

Source

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

:only-child

Browser Support

  • ক্রোম: 2।
  • প্রান্ত: 12।
  • ফায়ারফক্স: 1.5।
  • সাফারি: 3.1।

Source

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

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

Browser Support

  • ক্রোম: ১.
  • প্রান্ত: 12।
  • ফায়ারফক্স: 3.5।
  • সাফারি: 3.1।

Source

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

Browser Support

  • ক্রোম: ১.
  • প্রান্ত: 12।
  • ফায়ারফক্স: 3.5।
  • সাফারি: 3.1।

Source

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

Browser Support

  • ক্রোম: ১.
  • প্রান্ত: 12।
  • ফায়ারফক্স: 3.5।
  • সাফারি: 3.1।

Source

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

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

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

:empty

Browser Support

  • ক্রোম: ১.
  • প্রান্ত: 12।
  • ফায়ারফক্স: ১.
  • সাফারি: 3.1।

Source

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

Browser Support

  • ক্রোম: 88।
  • প্রান্ত: 88।
  • ফায়ারফক্স: 78।
  • সাফারি: 14।

Source

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

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

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

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

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

:not()

Browser Support

  • ক্রোম: ১.
  • প্রান্ত: 12।
  • ফায়ারফক্স: ১.
  • সাফারি: 3.1।

Source

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