खासियत

सीएसएस पॉडकास्ट - 003: खासियत

मान लें कि आपको यहां दिए गए एचटीएमएल और सीएसएस का इस्तेमाल करना है:

<button class="branding">Hello, Specificity!</button>
button {
  color: red;
}

.branding {
  color: blue;
}

यहां दो प्रतिस्पर्धी नियम दिए गए हैं. एक बटन को लाल रंग में दिखाया जाएगा और दूसरा उसे नीला रंग देगा. एलिमेंट पर कौनसा नियम लागू होता है? खासियत के बारे में सीएसएस की खास बातों के एल्गोरिदम को समझना यह जानने की कुंजी है कि सीएसएस, एक-दूसरे से जुड़े नियमों में से कोई नियम कैसे तय करती है.

खासियत, कैस्केड के चार अलग-अलग चरणों में से एक है. जो कि आखिरी मॉड्यूल में कैस्केड में कवर किया गया था.

विशेषता का स्कोर

सिलेक्टर के हर नियम को एक स्कोर दिया जाता है. इसे कुल स्कोर के तौर पर गिना जा सकता है. ऐसे में, सिलेक्टर के हर टाइप को उस स्कोर के हिसाब से पॉइंट मिलते हैं. जिस सिलेक्टर में सबसे ज़्यादा स्कोर होगा वह जीत जाएगा.

किसी असली प्रोजेक्ट की खासियत होने पर, बैलेंसिंग ऐक्ट से यह पक्का होता है कि आपको सीएसएस के जिन नियमों को लागू करना है, असल में लागू करें आम तौर पर, स्कोर को कम रखते हैं, ताकि मुश्किल न हो. स्कोर उतना ही ज़्यादा होना चाहिए जितना हमें चाहिए, यह सबसे ज़्यादा स्कोर करने की कोशिश करता है. आने वाले समय में, असल में कुछ और अहम सीएसएस लागू करने की ज़रूरत पड़ सकती है. अगर सबसे ज़्यादा स्कोर हासिल किया जाता है, तो यह कड़ी मुश्किल हो जाएगी.

हर सिलेक्टर टाइप के लिए स्कोर

सिलेक्टर के हर टाइप को पॉइंट मिलते हैं. सिलेक्टर की खासियत कैलकुलेट करने के लिए, इन सभी पॉइंट को जोड़ा जाता है.

यूनिवर्सल सिलेक्टर

यूनिवर्सल सिलेक्टर (*) कोई खास जानकारी नहीं है और उसे 0 पॉइंट मिलता है. इसका मतलब है कि एक या उससे ज़्यादा पॉइंट वाला कोई भी नियम इसे बदल देगा

* {
  color: red;
}

एलिमेंट या स्यूडो-एलिमेंट सिलेक्टर

कोई एलिमेंट (टाइप) या pseudo-element सिलेक्टर को 1 पॉइंट की खासियत मिलती है .

टाइप चुनने वाला

div {
  color: red;
}

बदली हुई पहचान वाला एलिमेंट सिलेक्टर

::selection {
  color: red;
}

क्लास, pseudo-class या एट्रिब्यूट चुनने वाला टूल

क्लास, pseudo-class या एट्रिब्यूट चुनने वाले टूल को 10 खास पॉइंट मिलते हैं.

क्लास चुनने का टूल

.my-class {
  color: red;
}

बदली हुई श्रेणी का सिलेक्टर

:hover {
  color: red;
}

एट्रिब्यूट चुनने वाला

[href='#'] {
  color: red;
}

:not() स्यूडो-क्लास, खासियत वाले कैलकुलेशन में कुछ नहीं जोड़ती. हालांकि, आर्ग्युमेंट के तौर पर पास किए गए सिलेक्टर, खास जानकारी के कैलकुलेशन में जुड़ जाते हैं.

div:not(.my-class) {
  color: red;
}

इस सैंपल में खासियत के 11 पॉइंट होंगे क्योंकि इसमें एक टाइप सिलेक्टर (div) और :not() के अंदर एक क्लास है.

आईडी चुनने वाला टूल

आईडी सिलेक्टर को 100 खास पॉइंट मिलते हैं, जब तक कि आप आईडी सिलेक्टर (#myID) का इस्तेमाल करें, न कि एट्रिब्यूट सिलेक्टर ([id="myID"]) का.

#myID {
  color: red;
}

इनलाइन स्टाइल एट्रिब्यूट

सीएसएस को सीधे एचटीएमएल एलिमेंट के style एट्रिब्यूट पर लागू किया जाता है, उसे 1,000 पॉइंट का स्पेसिफ़िकेशन स्कोर मिलता है. इसका मतलब है कि इसे सीएसएस में बदलने के लिए, आपको एक बहुत ही खास सिलेक्टर लिखना पड़ता है.

<div style="color: red"></div>

!important नियम

आखिर में, सीएसएस वैल्यू के आखिर में मौजूद !important को 10,000 पॉइंट का खास स्कोर मिलता है. यह किसी एक आइटम की सबसे खास खासियत है.

!important नियम को सीएसएस प्रॉपर्टी पर लागू किया जाता है, इसलिए, कुल नियम (सिलेक्टर और प्रॉपर्टी) में मौजूद हर चीज़ के लिए एक जैसा स्कोर नहीं मिलता.

.my-class {
  color: red !important; /* 10,000 points */
  background: white; /* 10 points */
}

देखें कि आपको कितना समझ आया है

विशेषज्ञता स्कोर के बारे में अपनी जानकारी को परखें

a[href="#"] की खासियत का स्कोर क्या है?

1
a का मूल्य 1 पॉइंट है, लेकिन [href="#"] का मूल्य 10 है.
5
फिर से कोशिश करें!
11
a का मूल्य 1 है और [href="#"] का मूल्य 10 है, जिससे कुल स्कोर 11 अंक होता है.

संदर्भ की खासियत

किसी एलिमेंट से मैच करने वाले हर सिलेक्टर की खासियत को एक साथ जोड़ दिया जाता है. इस एचटीएमएल के उदाहरण पर गौर करें:

<a class="my-class another-class" href="#">A link</a>

इस लिंक में दो क्लास हैं. इस सीएसएस को जोड़ें. इससे इसे एक खास पॉइंट मिल जाता है:

a {
  color: red;
}

इस नियम में दी गई क्लास में से किसी एक का रेफ़रंस दें, अब इसमें खास बातें 11 पॉइंट हैं:

a.my-class {
  color: green;
}

दूसरी क्लास को सिलेक्टर में जोड़ें, अब इसकी खासियत के 21 पॉइंट हैं:

a.my-class.another-class {
  color: rebeccapurple;
}

सिलेक्टर में href एट्रिब्यूट जोड़ें, अब इसमें 31 खास बातें हैं:

a.my-class.another-class[href] {
  color: goldenrod;
}

आखिर में,इन सभी में एक :hover pseudo-class जोड़ें, चुनने वाले टूल के आखिर में 41 खास बातें होती हैं:

a.my-class.another-class[href]:hover {
  color: lightgrey;
}

देखें कि आपको कितना समझ आया है

विशेषज्ञता स्कोर के बारे में अपनी जानकारी को परखें

इनमें से किस सिलेक्टर के लिए 21 पॉइंट के बराबर हैं?

article > section
एलिमेंट एक पॉइंट के बराबर होते हैं, सिलेक्टर में दो एलिमेंट होते हैं, इसलिए इसके 2 पॉइंट होते हैं.
article.card.dark
एलिमेंट में एक पॉइंट और क्लास के लिए 10 पॉइंट होते हैं. इसमें दो क्लास और एक एलिमेंट शामिल है, जिससे इस सिलेक्टर के लिए 21 पॉइंट मिलते हैं.
article:hover a[href]
एलिमेंट में एक पॉइंट, सूडो-क्लास, और एट्रिब्यूट के लिए 10 पॉइंट होते हैं. वहीं, एलिमेंट के लिए दो पॉइंट, एट्रिब्यूट और क्लास के लिए 20 पॉइंट, इस सिलेक्टर के लिए 22 पॉइंट के बराबर होते हैं.

किसी चीज़ को विज़ुअलाइज़ करना

डायग्राम और खासियत बताने वाले कैलकुलेटर में, खासियत को अक्सर इस तरह से दिखाया जाता है:

सबसे खास से लेकर सबसे कम चुनिंदा सिलेक्टर को दिखाने वाला डायग्राम

बायां ग्रुप id सिलेक्टर है. दूसरा ग्रुप, क्लास, एट्रिब्यूट, और स्यूडो-क्लास सिलेक्टर है. आखिरी ग्रुप, एलिमेंट और स्यूडो-एलिमेंट सिलेक्टर है.

रेफ़रंस के लिए, नीचे दिया गया सिलेक्टर 0-4-1 है:

a.my-class.another-class[href]:hover {
  color: lightgrey;
}

देखें कि आपको कितना समझ आया है

विज़ुअलाइज़ करने के बारे में अपनी जानकारी को परखें

इनमें से कौनसा सिलेक्टर 1-2-1 है?

section#specialty.dark
यह सिलेक्टर 1-1-1 के तौर पर दिखाया गया है.
#specialty:hover li.dark
🎉
[data-state-rad].dark#specialty:hover
यह सिलेक्टर 1-3-0 के तौर पर दिखाया गया है.
li#specialty section.dark
यह सिलेक्टर 1-1-2 के तौर पर दिखाया गया है.

व्यावहारिक तौर पर बढ़ती विशेषता

मान लें कि हमारे पास कुछ सीएसएस हैं, जो इस तरह दिखती हैं:

.my-button {
  background: blue;
}

button[onclick] {
  background: grey;
}

कुछ इस तरह दिखने वाले एचटीएमएल से:

<button class="my-button" onclick="alert('hello')">Click me</button>

इस बटन का बैकग्राउंड स्लेटी होता है, क्योंकि दूसरे सिलेक्टर को 11 खास पॉइंट (0-1-1) मिलते हैं. ऐसा इसलिए है, क्योंकि इसमें एक टाइप सिलेक्टर है (button), जो कि 1 पॉइंट है और एट्रिब्यूट सिलेक्टर ([onclick]) यानी कि 10 पॉइंट.

पिछले नियम—.my-button—को 10 पॉइंट (0-1-0) मिलेंगे, क्योंकि इसमें एक क्लास सिलेक्टर है.

अगर आपको इस नियम को बढ़ाना है, क्लास सिलेक्टर को इस तरह दोहराएं:

.my-button.my-button {
  background: blue;
}

button[onclick] {
  background: grey;
}

अब बटन का बैकग्राउंड नीला होगा, क्योंकि नए सिलेक्टर को 20 पॉइंट (0-2-0) का खास स्कोर मिलता है.

मैच होने वाले स्पेसिफ़िकिटी स्कोर के हिसाब से सबसे नया इंस्टेंस जीतता है

आइए, फ़िलहाल बटन के उदाहरण पर ही बने रहें और सीएसएस को इस पर स्विच करें:

.my-button {
  background: blue;
}

[onclick] {
  background: grey;
}

इस बटन का बैकग्राउंड स्लेटी होता है, क्योंकि दोनों सिलेक्टर का स्पेसिफ़िकिटी स्कोर एक जैसा है (0-1-0).

अगर नियमों को सोर्स के क्रम में बदला जाता है, तो तो बटन का रंग नीला हो जाएगा.

[onclick] {
  background: grey;
}

.my-button {
  background: blue;
}

सिर्फ़ इसी मामले में, नई सीएसएस जीतती है. ऐसा करने के लिए यह उस सिलेक्टर की विशेषता से मेल खाना चाहिए जो उसी एलिमेंट को टारगेट करता है.

संसाधन