खासियत

सीएसएस पॉडकास्ट - 003: खास जानकारी

मान लें कि आपके पास यह एचटीएमएल और सीएसएस है:

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

button {
  color: red;
}

यहां एक ही एलिमेंट को टारगेट करने वाले दो नियम हैं. हर नियम में एक एलान होता है, जो बटन का रंग सेट करना चाहता है: एक बटन को लाल रंग में रंगने की कोशिश करता है और दूसरा उसे नीले रंग में रंगने की कोशिश करता है. एलिमेंट पर कौनसा एलान लागू होता है?

सीएसएस स्पेसिफ़िसिटी एल्गोरिदम को समझने से, यह समझने में मदद मिलती है कि सीएसएस, एक-दूसरे से मेल खाने वाले एलान के बीच कैसे फ़ैसला लेती है.

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

खास जानकारी देने के लिए स्कोर

ऑरिजिन में मौजूद हर सिलेक्टर नियम को स्कोर मिलता है. सटीक जानकारी को कुल स्कोर के तौर पर देखा जा सकता है. साथ ही, हर तरह के सिलेक्टर को उस स्कोर के लिए पॉइंट मिलते हैं. सबसे सटीक नियमों के एलान को प्राथमिकता दी जाती है.

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

खास जानकारी दशमलव वाली संख्या नहीं होती, बल्कि यह एक ट्रायड होती है, जिसमें तीन कॉम्पोनेंट होते हैं: A, B, और C.

  • A: आईडी जैसी खास जानकारी
  • B: क्लास की तरह खास जानकारी
  • C: एलिमेंट की तरह खास जानकारी

इसे अक्सर (A,B,C) नोटेशन का इस्तेमाल करके दिखाया जाता है. उदाहरण के लिए: (1,0,2). आम तौर पर, A-B-C के अन्य नोटेशन का भी इस्तेमाल किया जाता है.

खास जानकारी के तीन कॉम्पोनेंट (A,B,C) दिखाने वाला डायग्राम. डायग्राम में हर कॉम्पोनेंट के बारे में बताया गया है कि वह क्या दिखाता है. साथ ही, उस पर असर डालने वाले कुछ चुनिंदा सिलेक्टर के बारे में भी बताया गया है.
यह डायग्राम दिखाता है कि अलग-अलग सिलेक्टर, खास जानकारी के किस कॉम्पोनेंट पर असर डालते हैं.

खास बातों की तुलना करना

खास जानकारी की तुलना करने के लिए, तीन कॉम्पोनेंट की तुलना इस क्रम में की जाती है: A वैल्यू जितनी ज़्यादा होगी, खास जानकारी उतनी ही ज़्यादा सटीक होगी; अगर A की दो वैल्यू बराबर हों, तो B की ज़्यादा वैल्यू वाली खास जानकारी ज़्यादा सटीक होगी; अगर B की दो वैल्यू भी बराबर हों, तो C की ज़्यादा वैल्यू वाली खास जानकारी ज़्यादा सटीक होगी; अगर सभी वैल्यू बराबर हों, तो दोनों खास जानकारी बराबर होंगी.

उदाहरण के लिए, (1,0,0) को (0,4,3) से ज़्यादा सटीक माना जाता है, क्योंकि (1,0,0) में A वैल्यू (जो 1 है) (0,4,3) की A वैल्यू (जो 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 कॉम्पोनेंट की वैल्यू एक बढ़ जाती है. ऐसा तब तक होता है, जब तक एट्रिब्यूट चुनने वाले टूल ([id="myID"]) के बजाय, आईडी चुनने वाले टूल (#myID) का इस्तेमाल किया जाता है.

नीचे दिए गए उदाहरण में, खास जानकारी (1,0,0) है

#myID {
  color: red;
}

अन्य सिलेक्टर

सीएसएस में कई सिलेक्टर होते हैं. इनमें से सभी एट्रिब्यूट, खास जानकारी नहीं देते. उदाहरण के लिए, :not() स्यूडो-क्लास, सटीक जानकारी के हिसाब से कैलकुलेट नहीं की जाती.

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

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

इस सैंपल में (0,1,1) का इस्तेमाल किया गया है, क्योंकि इसमें :not() में एक टाइप सिलेक्टर (div) और एक क्लास है.

देखें कि आपको क्या समझ आया

खास जानकारी देने के लिए स्कोर करने की सुविधा के बारे में अपनी जानकारी की जांच करें

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

(0,0,1)
a की वैल्यू (0,0,1) है, लेकिन [href="#"] की वैल्यू (0,1,0) है.
(0,1,0)
फिर से कोशिश करें! a की वैल्यू (0,0,1) है, लेकिन [href="#"] की वैल्यू (0,1,0) है.
(0,1,1)
a की वैल्यू (0,0,1) और [href="#"] की वैल्यू (0,1,0) है. कुल वैल्यू (0,1,1) है.

ऐसे फ़ैक्टर जिनका सटीक जानकारी पर कोई असर नहीं पड़ता

सटीक जानकारी देने पर असर डालने वाले इन फ़ैक्टर के बारे में कुछ आम गलतफ़हमियां हैं.

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

सीएसएस को सीधे किसी एलिमेंट के style एट्रिब्यूट पर लागू करने से, सटीक जानकारी पर असर नहीं पड़ता. ऐसा इसलिए, क्योंकि यह कैस्केड में एक अलग चरण है, जिसका आकलन सटीक जानकारी से पहले किया जाता है.

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

किसी स्टाइल शीट में इस एलान को बदलने के लिए, आपको कैस्केड के किसी पिछले चरण में एलान को लागू करना होगा.

उदाहरण के लिए, इसमें !important जोड़ा जा सकता है, ताकि यह लेखक के !important ऑरिजिन का हिस्सा बन जाए.

!important एलान

सीएसएस एलान के आखिर में !important होने से, एलान की खास जानकारी पर कोई असर नहीं पड़ता. हालांकि, एलान को किसी दूसरे ऑरिजिन में डाल दिया जाता है. जैसे, लेखक का !important.

नीचे दिए गए उदाहरण में, .my-class के बारे में जानकारी, !important के एलान के लिए ज़रूरी नहीं है.

.my-class {
  color: red !important;
  color: white;
}

जब दो एलान !important होते हैं, तो फिर से खास जानकारी का इस्तेमाल किया जाता है, क्योंकि कैस्केड के ऑरिजिन चरण से अब तक यह तय नहीं हो पाया था कि कौनसा एलान विजेता है.

.branding {
  color: blue !important;
}

button {
  color: red !important;
}

कॉन्टेक्स्ट में खास जानकारी

जब किसी कॉम्प्लेक्स या कंपाउंड सिलेक्टर का इस्तेमाल किया जाता है, तो उस सिलेक्टर का हर हिस्सा, ज़्यादा सटीक नतीजे देता है. इस एचटीएमएल उदाहरण पर ध्यान दें:

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

इस लिंक में दो क्लास हैं. नीचे दी गई सीएसएस में मौजूद नियम में (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 स्यूडो-क्लास जोड़ें, सिलेक्टर (0,4,1) की खास जानकारी के साथ खत्म होता है:

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

देखें कि आपको क्या समझ आया

खास जानकारी देने के आधार पर स्कोर करने की सुविधा के बारे में अपनी जानकारी की जांच करना

इनमें से किस सिलेक्टर में (0,2,1) की खास जानकारी है?

article > section
एलिमेंट, एलिमेंट की तरह खास जानकारी जोड़ते हैं (`C` कॉम्पोनेंट). सिलेक्टर में दो एलिमेंट हैं, इसलिए इसकी खास बात (0,0,2) है.
article.card.dark
एलिमेंट, एलिमेंट जैसी खास जानकारी जोड़ते हैं (`C` कॉम्पोनेंट), जबकि क्लास, क्लास जैसी खास जानकारी जोड़ती हैं (`B` कॉम्पोनेंट). दो क्लास और एक एलिमेंट के साथ, इस सिलेक्टर की खासियत (0,2,1) है.
article:hover a[href]
एलिमेंट, एलिमेंट जैसी खास जानकारी जोड़ते हैं (`C` कॉम्पोनेंट), स्यूडो-क्लास और एट्रिब्यूट, क्लास जैसी खास जानकारी जोड़ते हैं (`B` कॉम्पोनेंट). इसमें दो एलिमेंट सिलेक्टर (2 × (0,0,1)), एक एट्रिब्यूट सिलेक्टर ((0,0,1)) और एक क्लास सिलेक्टर ((0,0,1)) है. इस वजह से, इस सिलेक्टर की कुल वैल्यू (0,2,2) है.

ज़्यादा सटीक जानकारी देना

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

.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;
}

ऐसा इसलिए है, क्योंकि दोनों सिलेक्टर की खास बात एक ही है. इस मामले में, कैस्केड दिखने के क्रम के चरण पर वापस आ जाता है.

संसाधन