সিএসএস পডকাস্ট - 003: নির্দিষ্টতা
ধরুন আপনি নিম্নলিখিত HTML এবং CSS এর সাথে কাজ করছেন:
<button class="branding">Hello, Specificity!</button>
.branding {
color: blue;
}
button {
color: red;
}
এখানে একই উপাদান লক্ষ্য দুটি নিয়ম আছে. প্রতিটি নিয়মে একটি ঘোষণা রয়েছে যা বোতামের রঙ সেট করতে চায়: একটি বোতামটিকে লাল রঙ করার চেষ্টা করে এবং অন্যটি এটিকে নীল রঙ করার চেষ্টা করে। কোন ঘোষণা উপাদান প্রয়োগ করা হয়?
CSS নির্দিষ্টতা অ্যালগরিদম বোঝা হল প্রতিযোগী ঘোষণার মধ্যে CSS কীভাবে সিদ্ধান্ত নেয় তা বোঝার চাবিকাঠি।
নির্দিষ্টতা হল ক্যাসকেডের একটি স্বতন্ত্র পর্যায়, যা ক্যাসকেডের শেষ মডিউলে আচ্ছাদিত ছিল।
নির্দিষ্টতা স্কোরিং
একটি মূলের মধ্যে প্রতিটি নির্বাচক নিয়ম একটি স্কোরিং পায়। আপনি নির্দিষ্টতাকে মোট স্কোর হিসাবে ভাবতে পারেন এবং প্রতিটি নির্বাচকের ধরন সেই স্কোরের দিকে পয়েন্ট অর্জন করে। সর্বোচ্চ নির্দিষ্টতা জয়ের সাথে নিয়ম থেকে ঘোষণা।
একটি বাস্তব প্রজেক্টের নির্দিষ্টতার সাথে, ব্যালেন্সিং অ্যাক্ট নিশ্চিত করছে যে আপনি যে CSS নিয়মগুলি প্রয়োগ করতে চান, বাস্তবে প্রয়োগ করা হয়, সাধারণত জটিলতা রোধ করতে স্কোর কম রাখা হয়। সম্ভাব্য সর্বোচ্চ নির্দিষ্টতার লক্ষ্য না করে নির্দিষ্টতা আমাদের যতটা প্রয়োজন ততটা হওয়া উচিত। ভবিষ্যতে, কিছু সত্যিকারের আরও গুরুত্বপূর্ণ CSS প্রয়োগ করার প্রয়োজন হতে পারে। আপনি যদি সর্বোচ্চ নির্দিষ্টতার জন্য যান, আপনি সেই কাজটিকে কঠিন করে তুলবেন।
নির্দিষ্টতা একটি দশমিক সংখ্যা নয় কিন্তু একটি ত্রয়ী যা তিনটি উপাদান নিয়ে গঠিত: A
, B
, এবং C
-
A
: আইডির মতো নির্দিষ্টতা -
B
: শ্রেণীর মত নির্দিষ্টতা -
C
: উপাদানের মতো নির্দিষ্টতা
এটি প্রায়ই (A,B,C)
স্বরলিপি ব্যবহার করে উপস্থাপন করা হয়। উদাহরণস্বরূপ: (1,0,2)
। বিকল্প ABC
স্বরলিপিও সাধারণত ব্যবহৃত হয়।
বিশেষত্ব তুলনা
ক্রমানুসারে তিনটি উপাদানের তুলনা করে নির্দিষ্টতা তুলনা করা হয়: একটি বড় A মান সহ নির্দিষ্টতা আরও নির্দিষ্ট; যদি দুটি A মান বাঁধা হয়, তাহলে একটি বৃহত্তর B মানের সাথে নির্দিষ্টতা আরও সুনির্দিষ্ট; যদি দুটি B মানও বাঁধা হয়, তাহলে একটি বৃহত্তর C মানের সাথে নির্দিষ্টতা আরও সুনির্দিষ্ট; যদি সমস্ত মান বাঁধা হয়, দুটি নির্দিষ্টতা সমান।
উদাহরণস্বরূপ, (1,0,0)
(0,4,3)
এর চেয়ে উচ্চতর নির্দিষ্টতা হিসাবে বিবেচনা করা হয় কারণ (1,0,0)
এর A
মান (যা 1
) (0,4,3)
) থেকে A
মানের চেয়ে বেশি (0,4,3)
(যা 0
)
নির্বাচকরা নির্দিষ্টতা প্রভাবিত করে
নির্দিষ্টতা ট্রায়াডের প্রতিটি অংশ 0
এর মান দিয়ে শুরু হয়, তাই ডিফল্ট নির্দিষ্টতা হল (0,0,0)
। নির্বাচকের প্রতিটি অংশ নির্দিষ্টতা বাড়ায় যা নির্বাচকের প্রকারের উপর নির্ভর করে, A
, B
, বা C
এর মান বৃদ্ধি করে।
সর্বজনীন নির্বাচক
একটি সার্বজনীন নির্বাচক ( *
) কোন নির্দিষ্টতা যোগ করে না, এর মান (0,0,0)
এর প্রাথমিক নির্দিষ্টতায় রেখে যায়।
* {
color: red;
}
এলিমেন্ট বা ছদ্ম-উপাদান নির্বাচক
একটি উপাদান (টাইপ) বা ছদ্ম-উপাদান নির্বাচক উপাদানের মতো নির্দিষ্টতা যোগ করে যা C
উপাদানকে 1
দ্বারা বৃদ্ধি করে।
নিম্নলিখিত উদাহরণগুলির একটি সামগ্রিক নির্দিষ্টতা রয়েছে (0,0,1)
।
টাইপ নির্বাচক
div {
color: red;
}
ছদ্ম-উপাদান নির্বাচক
::selection {
color: red;
}
ক্লাস, সিউডো-ক্লাস, বা অ্যাট্রিবিউট সিলেক্টর
একটি শ্রেণী , ছদ্ম-শ্রেণী বা বৈশিষ্ট্য নির্বাচক শ্রেণী-মত নির্দিষ্টতা যোগ করে যা B
উপাদানকে 1
দ্বারা বৃদ্ধি করে।
নিম্নলিখিত উদাহরণগুলির একটি নির্দিষ্টতা রয়েছে (0,1,0)
।
ক্লাস নির্বাচক
.my-class {
color: red;
}
ছদ্ম-শ্রেণী নির্বাচক
:hover {
color: red;
}
বৈশিষ্ট্য নির্বাচক
[href='#'] {
color: red;
}
আইডি নির্বাচক
একটি আইডি নির্বাচক আইডি-এর মতো নির্দিষ্টতা যোগ করে যা A
উপাদানটিকে 1 দ্বারা বৃদ্ধি করে, যতক্ষণ না আপনি একটি আইডি নির্বাচক ( #myID
) ব্যবহার করেন এবং একটি বৈশিষ্ট্য নির্বাচক ( [id="myID"]
) ব্যবহার করেন না।
নিম্নলিখিত উদাহরণে, নির্দিষ্টতা হল (1,0,0)
#myID {
color: red;
}
অন্যান্য নির্বাচক
CSS এর অনেক নির্বাচক রয়েছে। তাদের সব নির্দিষ্টতা যোগ না. উদাহরণস্বরূপ, :not()
ছদ্ম-শ্রেণী নিজেই নির্দিষ্টতা গণনার সাথে কিছুই যোগ করে না।
যাইহোক, নির্বাচকরা আর্গুমেন্ট হিসাবে পাস করে নির্দিষ্টতা গণনায় যোগ করা হয়।
div:not(.my-class) {
color: red;
}
এই নমুনার একটি নির্দিষ্টতা (0,1,1) কারণ এটির একটি প্রকার নির্বাচক ( div
) এবং :not()
এর ভিতরে একটি শ্রেণী রয়েছে।
আপনার উপলব্ধি পরীক্ষা করুন
নির্দিষ্টতা স্কোরিং আপনার জ্ঞান পরীক্ষা
a[href="#"]
এর নির্দিষ্টতা কী?
(0,1,1)
(0,1,0)
(0,0,1)
যে কারণগুলি নির্দিষ্টতা প্রভাবিত করে না
নির্দিষ্টতা প্রভাবিত নিম্নলিখিত কারণ সম্পর্কে কিছু সাধারণ ভুল ধারণা আছে.
ইনলাইন শৈলী বৈশিষ্ট্য
একটি উপাদানের style
বৈশিষ্ট্যে সরাসরি CSS প্রয়োগ করা হয়, নির্দিষ্টতাকে প্রভাবিত করে না কারণ এটি ক্যাসকেডের একটি ভিন্ন ধাপ যা নির্দিষ্টতার আগে মূল্যায়ন করা হয়।
<div style="color: red"></div>
একটি স্টাইল শীটের মধ্যে থেকে এই ঘোষণাটি ওভাররাইড করার জন্য, আপনাকে ক্যাসকেডের পূর্ববর্তী ধাপে ঘোষণার জয় পেতে অবলম্বন করতে হবে।
উদাহরণস্বরূপ, আপনি এতে !important
যোগ করতে পারেন, যাতে এটি অথরেড !important
মূলের অংশ হয়ে যায়।
!important
ঘোষণা
CSS ঘোষণার শেষে একটি !important
নির্দিষ্টতাকে প্রভাবিত করে না কিন্তু ঘোষণাটিকে একটি ভিন্ন মূলে রাখে, যথা Authored !important
।
নিম্নলিখিত উদাহরণে, .my-class
এর নির্দিষ্টতা জয়ের জন্য !important
ঘোষণার জন্য প্রাসঙ্গিক নয়৷
.my-class {
color: red !important;
color: white;
}
যখন দুটি ঘোষণা !important
, তখন নির্দিষ্টতা আবার খেলায় আসে, কারণ ক্যাসকেড থেকে উৎপত্তি পদক্ষেপটি এখনও বিজয়ী নির্ধারণ করতে সক্ষম হয়নি৷
.branding {
color: blue !important;
}
button {
color: red !important;
}
প্রসঙ্গে নির্দিষ্টতা
যখন একটি জটিল বা যৌগ নির্বাচক ব্যবহার করা হয়, সেই নির্বাচকের প্রতিটি অংশ নির্দিষ্টতা পর্যন্ত যোগ করে। এই উদাহরণ HTML বিবেচনা করুন:
<a class="my-class another-class" href="#">A link</a>
এই লিঙ্কে দুটি ক্লাস আছে। নিম্নলিখিত CSS-এর নিয়মটির একটি নির্দিষ্টতা রয়েছে (0,0,1)
:
a {
color: red;
}
আপনি যদি নির্বাচকের ক্লাসগুলির মধ্যে একটি উল্লেখ করেন তবে এটির এখন (0,1,1)
একটি নির্দিষ্টতা রয়েছে:
a.my-class {
color: green;
}
নির্বাচকের সাথে অন্য শ্রেণী যোগ করুন, এটির এখন (0,2,1)
একটি নির্দিষ্টতা রয়েছে:
a.my-class.another-class {
color: rebeccapurple;
}
নির্বাচকের সাথে href
অ্যাট্রিবিউট যোগ করুন, এটির এখন একটি নির্দিষ্টতা রয়েছে (0,3,1)
:
a.my-class.another-class[href] {
color: goldenrod;
}
সবশেষে, একটি :hover
pseudo-class যোগ করুন, নির্বাচক (0,4,1)
এর একটি নির্দিষ্টতার সাথে শেষ হয় :
a.my-class.another-class[href]:hover {
color: lightgrey;
}
আপনার উপলব্ধি পরীক্ষা করুন
নির্দিষ্টতা স্কোরিং আপনার জ্ঞান পরীক্ষা
নিচের কোন নির্বাচকের (0,2,1)
একটি নির্দিষ্টতা আছে?
article.card.dark
article:hover a[href]
article > section
বাস্তবসম্মতভাবে নির্দিষ্টতা বৃদ্ধি
বলুন আপনার কিছু CSS আছে যা দেখতে এইরকম:
.my-button {
background: blue;
}
button[onclick] {
background: grey;
}
এইচটিএমএল এর সাথে যা এইরকম দেখায়:
<button class="my-button" onclick="alert('hello')">Click me</button>
বোতামটির একটি ধূসর পটভূমি রয়েছে, কারণ দ্বিতীয় নির্বাচকের একটি নির্দিষ্টতা রয়েছে (0,1,1)
। কারণ এটিতে এক প্রকার নির্বাচক ( button
), যা (0,0,1)
এবং একটি বৈশিষ্ট্য নির্বাচক ( [onclick]
), যা (0,1,0)
।
পূর্ববর্তী নিয়ম .my-button
—সমান (0,1,0)
কারণ এতে একটি শ্রেণী নির্বাচক রয়েছে, যা (0,1,1)
এর চেয়ে কম নির্দিষ্টতা।
আপনি যদি এই নিয়মটি একটি বুস্ট দিতে চান, আপনি এইভাবে ক্লাস সিলেক্টর পুনরাবৃত্তি করতে পারেন:
.my-button.my-button {
background: blue;
}
button[onclick] {
background: grey;
}
এখন, বোতামটির একটি নীল পটভূমি থাকবে, কারণ নতুন নির্বাচক একটি নির্দিষ্টতা পায় (0,2,0)
নির্দিষ্টতার একটি টাই ক্যাসকেডের পরবর্তী ধাপে ফিরে আসে
আপাতত বোতামের উদাহরণের সাথেই থাকুন এবং সিএসএসকে এটিতে স্যুইচ করুন:
.my-button {
background: blue;
}
[onclick] {
background: grey;
}
বোতামটির একটি ধূসর পটভূমি রয়েছে, কারণ উভয় নির্বাচকেরই (0,1,0)
একটি অভিন্ন নির্দিষ্টতা রয়েছে।
আপনি যদি উত্স ক্রমে নিয়মগুলি স্যুইচ করেন তবে বোতামটি নীল হবে৷
[onclick] {
background: grey;
}
.my-button {
background: blue;
}
এর কারণ উভয় নির্বাচকদের একই নির্দিষ্টতা রয়েছে। এই ক্ষেত্রে, ক্যাসকেড চেহারা ধাপের ক্রম ফিরে পড়ে।