ছদ্ম-শ্রেণী

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

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

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

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

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

:hover

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

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

উৎস

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

:active

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

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

উৎস

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

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

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

  • ক্রোম: ১.
  • প্রান্ত: 12।
  • ফায়ারফক্স: ১.
  • সাফারি: 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

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

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

উৎস

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

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

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

#content:target {
    background: yellow;
}

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

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

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

  • ক্রোম: ১.
  • প্রান্ত: 12।
  • ফায়ারফক্স: ১.
  • সাফারি: 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

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

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

উৎস

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

:checked এবং :indeterminate

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

  • ক্রোম: ১.
  • প্রান্ত: 12।
  • ফায়ারফক্স: ১.
  • সাফারি: 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

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

  • ক্রোম: ১.
  • প্রান্ত: 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

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

  • ক্রোম: ১.
  • প্রান্ত: 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

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

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

উৎস

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

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

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

:empty

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

  • ক্রোম: ১.
  • প্রান্ত: 12।
  • ফায়ারফক্স: ১.
  • সাফারি: 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()

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

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

উৎস

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

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

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

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

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

:not()

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

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

উৎস

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

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

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

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

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

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

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

মিথ্যা
সত্য

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

:target
:is()
:empty
:not()

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

:hover
:press
:focus-within
:squeeze
:target

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

:checked
:fresh
:in-range
:enabled
:loading
:valid
:indeterminate