An+B लॉजिक लागू करने से पहले, चाइल्ड एलिमेंट के सेट को प्री-फ़िल्टर करें.
:nth-child() और :nth-last-child() स्यूडो-क्लास सिलेक्टर
:nth-child() स्यूडो-क्लास सिलेक्टर की मदद से, डीओएम में मौजूद एलिमेंट को उनके इंडेक्स के हिसाब से चुना जा सकता है. An+B माइक्रोसेंटेक्स का इस्तेमाल करके, यह तय किया जा सकता है कि आपको किन एलिमेंट को चुनना है.
:nth-child(2): दूसरे बच्चे का नाम चुनें.:nth-child(2n): सभी सम संख्या वाले चाइल्ड एलिमेंट (दूसरा, चौथा, छठा, आठवाँ वगैरह) चुनें.:nth-child(2n+1): यह सभी विषम चाइल्ड एलिमेंट (पहला, तीसरा, पांचवां, सातवां वगैरह) को चुनता है.:nth-child(5n+1): पहला (=(5×0)+1), छठा (=(5×1)+1), 11वां (=(5×2)+1), … चाइल्ड चुनें.:nth-child(5n+2): दूसरा (=(5×0)+2), सातवां (=(5×1)+2), 12वां (=(5×2)+2), … चाइल्ड चुनें.
हालांकि, A पैरामीटर को शामिल न करने पर, क्रिएटिव के ज़्यादा विकल्प चुने जा सकते हैं. उदाहरण के लिए:
:nth-child(n+3): तीसरे एलिमेंट से लेकर आखिर तक के सभी चाइल्ड एलिमेंट (तीसरा, चौथा, पांचवां वगैरह) चुनें.:nth-child(-n+5): यह पहले से पांचवें तक के हर चाइल्ड को चुनता है (पहला, दूसरा, तीसरा, चौथा, पांचवां).
इन :nth-child() विकल्पों को मिलाकर, एलिमेंट की रेंज चुनी जा सकती हैं:
:nth-child(n+3):nth-child(-n+5): तीसरे से लेकर पांचवें तक के हर चाइल्ड को चुनें (तीसरा, चौथा, पांचवां).
:nth-last-child() का इस्तेमाल करके, इसी तरह के सिलेक्शन किए जा सकते हैं. हालांकि, इसमें गिनती शुरू से करने के बजाय आखिर से की जाती है.
of S सिंटैक्स का इस्तेमाल करके, पहले से फ़िल्टर किए गए विकल्पों को चुनना
सीएसएस सिलेक्टर लेवल 4 में नया यह है कि :nth-child() और :nth-last-child() में सिलेक्टर सूची को पास करने की सुविधा है.
:nth-child(An+B [of S]?)
:nth-last-child(An+B [of S]?)
of S तय किए जाने पर, An+B लॉजिक सिर्फ़ उन एलिमेंट पर लागू होता है जो दी गई सिलेक्टर लिस्ट S से मेल खाते हैं. इसका मतलब है कि An+B के काम करने से पहले, बच्चों के लिए कॉन्टेंट को फ़िल्टर किया जा सकता है.
Browser Support
उदाहरण
उदाहरण के लिए, :nth-child(2 of .highlight), .highlight क्लास वाले दूसरे मैचिंग एलिमेंट को चुनता है. दूसरे शब्दों में: क्लास .highlight में मौजूद सभी बच्चों में से, दूसरे बच्चे को चुनें.
यह .highlight:nth-child(2) से अलग है. .highlight:nth-child(2) उस एलिमेंट को चुनता है जिसकी क्लास .highlight और दूसरा चाइल्ड भी है.
नीचे दिए गए डेमो में, इस अंतर को देखा जा सकता है:
:nth-child(2 of .highlight)से मेल खाने वाले एलिमेंट के चारों ओर गुलाबी रंग की आउटलाइन है..highlight:nth-child(2)से मेल खाने वाले एलिमेंट के चारों ओर हरे रंग की आउटलाइन होती है.
ध्यान दें कि S एक सिलेक्टर लिस्ट है. इसका मतलब है कि यह कॉमा से अलग किए गए कई सिलेक्टर स्वीकार करती है. उदाहरण के लिए, :nth-child(4 of .highlight, .sale), सिबलिंग के सेट में से चौथा एलिमेंट चुनता है. यह एलिमेंट .highlight या .sale हो सकता है.
नीचे दिए गए डेमो में, :nth-child(4 of .highlight, .sale) से मेल खाने वाले एलिमेंट पर नारंगी रंग की आउटलाइन लगाई गई है.
ज़ेब्रा-स्ट्राइपिंग की सुविधा को फिर से देखना
:nth-child() का इस्तेमाल करने का एक क्लासिक उदाहरण, ज़ेब्रा-स्ट्राइप्ड टेबल बनाते समय होता है. यह एक विज़ुअल तकनीक है, जिसमें टेबल की हर लाइन का रंग बदलता रहता है. आम तौर पर, इसे इस तरह से हल किया जाता है:
tr:nth-child(even) {
background-color: lightgrey;
}
यह स्टैटिक टेबल के लिए ठीक से काम करता है. हालांकि, जब टेबल के कॉन्टेंट को डाइनैमिक तरीके से फ़िल्टर किया जाता है, तो यह समस्या पैदा करता है. उदाहरण के लिए, दूसरी लाइन को छिपाने पर, पहली और तीसरी लाइन दिखेंगी. इन दोनों लाइनों का बैकग्राउंड एक ही रंग का होगा.
इस समस्या को ठीक करने के लिए, हम :nth-child(An+B [of S]?) का इस्तेमाल कर सकते हैं. इसके लिए, :nth-child(An+B [of S]?) के लॉजिक से छिपी हुई पंक्तियों को बाहर रखा जाता है:An+B
tr:nth-child(even of :not([hidden])) {
background-color: lightgrey;
}
यह काफ़ी अच्छा है, है न?
Unsplash पर Markus Spiske की फ़ोटो