क्या सीएसएस 2.1 :after
और सीएसएस 3 ::after
छद्म चयनकर्ताओं ( ::after
पुराने ब्राउज़रों में समर्थित नहीं होने के अलावा ) के बीच कोई कार्यात्मक अंतर है ? क्या नए विनिर्देशन का उपयोग करने का कोई व्यावहारिक कारण है?
क्या सीएसएस 2.1 :after
और सीएसएस 3 ::after
छद्म चयनकर्ताओं ( ::after
पुराने ब्राउज़रों में समर्थित नहीं होने के अलावा ) के बीच कोई कार्यात्मक अंतर है ? क्या नए विनिर्देशन का उपयोग करने का कोई व्यावहारिक कारण है?
जवाबों:
यह छद्म वर्ग बनाम छद्म तत्व भेद है।
सिवाय के लिए ::first-line
, ::first-letter
, ::before
और ::after
(जबकि और एकल कोलन के साथ इस्तेमाल किया जा सकता है अगर आप IE8 समर्थन की आवश्यकता होती है जो एक छोटे से आसपास किया गया है), छद्म तत्वों की आवश्यकता होती है डबल कोलन।
छद्म कक्षाएं वास्तविक तत्व खुद को चुनते हैं, तो आप उपयोग कर सकते :first-child
या :nth-of-type(n)
पहले या विशिष्ट के चयन के लिए <p>
एक div में है, उदाहरण के लिए।
(और भी तरह वास्तविक तत्वों के राज्यों :hover
और :focus
।)
छद्म तत्व ऐसे तत्व के उप-भाग को लक्षित करते हैं जैसे ::first-line
या ::first-letter
, ऐसी चीजें जो अपने आप में तत्व नहीं हैं।
वास्तव में, यहाँ बेहतर विवरण: http://bricss.net/post/10768584657/know-your-lingo-pseudo-class-vs-pseudo-element
यहाँ भी: http://www.evotech.net/blogsp7/ 05 / के बाद वी के बाद क्या-है-डबल बृहदान्त्र-अंकन /
:after
और ::after
परस्पर विनिमय कर सकते हैं , जो कि प्रश्न नोटों के रूप में एकल बृहदान्त्र की आवश्यकता है।
CSS चयनकर्ता ::after
कुछ आभासी तत्व हैं जो DOM ट्री में एक स्पष्ट तत्व के रूप में उपलब्ध नहीं हैं। वे "कहा जाता है छद्म तत्वों " और करने के लिए उपयोग किया जाता है सम्मिलित एक तत्व के बाद / पहले कुछ सामग्री (जैसे: ::before
, ::after
) या कुछ हिस्से का चयन करें एक तत्व के (जैसे: ::first-letter
)। वर्तमान में केवल 5 मानक छद्म तत्व हैं after, before, first-letter, first-line, selection
:।
दूसरी ओर, वहाँ चयनकर्ताओं "कहा जाता है के अन्य प्रकार हैं छद्म वर्ग है जो एक परिभाषित किया जाता है" विशेष राज्य (के रूप में की तरह एक तत्व की :hover
, :focus
, :nth-child(n)
)। ये DOM में किसी मौजूदा तत्व का चयन करेंगे। छद्म वर्ग 30 से अधिक वस्तुओं के साथ एक लंबी सूची है।
प्रारंभ में (CSS2 और CSS1 में), एकल-कोलोन सिंटैक्स का उपयोग छद्म वर्गों और छद्म तत्वों दोनों के लिए किया गया था। लेकिन, CSS3 में ::
सिंटैक्स ने :
छद्म तत्वों के लिए संकेतन को बेहतर ढंग से अलग करने की जगह ले ली ।
पिछड़े संगतता के लिए, पुराना एकल-कोलोन सिंटैक्स छद्म तत्वों के लिए स्वीकार्य है जैसे :after
(ब्राउज़र अभी भी सभी एक सिक्कोल के साथ पुराने सिंटैक्स का समर्थन करते हैं)। केवल IE-8 नए सिंटैक्स का समर्थन नहीं करता है (यदि आप IE8 का समर्थन करना चाहते हैं तो एकल-कॉलन का उपयोग करें)।