एक unordered सूची की कल्पना करें:
& lt; ul id = "something" & gt; & Lt; li वर्ग = "अभिभावक" & gt; अभिभावक & lt; / li & gt; & Lt; li वर्ग = "अभिभावक" & gt; अभिभावक & lt; / li & gt; & Lt; li वर्ग = "बाल" & gt; बाल & lt; / li & gt; & Lt; li वर्ग = "बाल" & gt; बाल & lt; / li & gt; & Lt; li वर्ग = "अभिभावक" & gt; अभिभावक & lt; / li & gt; & Lt; li वर्ग = "अभिभावक" & gt; अभिभावक & lt; / li & gt; & Lt; li वर्ग = "बाल" & gt; बाल & lt; / li & gt; & Lt; li वर्ग = "बाल" & gt; बाल & lt; / li & gt; & Lt; / ul & gt;
मैं उपर्युक्त उदाहरण को इसमें बदलना चाहता हूं:
& lt; ul id = "something" & gt; & Lt; li वर्ग = "अभिभावक" & gt; अभिभावक & lt; / li & gt; & Lt; li वर्ग = "अभिभावक" & gt; अभिभावक & lt; / li & gt; & LT; ul & gt; & Lt; li वर्ग = "बाल" & gt; बाल & lt; / li & gt; & Lt; li वर्ग = "बाल" & gt; बाल & lt; / li & gt; & Lt; / ul & gt; & Lt; li वर्ग = "अभिभावक" & gt; अभिभावक & lt; / li & gt; & Lt; li वर्ग = "अभिभावक" & gt; अभिभावक & lt; / li & gt; & LT; ul & gt; & Lt; li वर्ग = "बाल" & gt; बाल & lt; / li & gt; & Lt; li वर्ग = "बाल" & gt; बाल & lt; / li & gt; & Lt; / ul & gt; & Lt; / ul & gt;
मैंने यहां पाया समाधान के आधार पर यह सफलतापूर्वक किया है:
$ ('# कुछ')। बच्चों ('li.child: नहीं (Li.child + li.child) ')। प्रत्येक (फ़ंक्शन () {$ (यह) .nextUntil (' li.parent ') और स्वयं ()। लपेटो (' & lt; ul / & gt; ');}) ;
अगर मैं इसका उपयोग नहीं करता हूं: नहीं (चयनकर्ता + चयनकर्ता) यह अजीब निरंतर एम्बेडिंग का कारण होता है ul> li> ul> li, आदि।
तो मूल रूप से मैं सिर्फ इसे स्पष्ट रूप से समझना चाहता हूं।
कार्य
यह कोड का वर्णन करता है कदम से कदम यह क्या करता है
यह पहला बच्चा चुनता है, और उनमें से प्रत्येक के लिए, अपने सभी भाइयों को इकट्ठा करके अगले माता पिता को स्वयं सहित, और उस संग्रह को ul
में लपेटें।
या:
एनोटेड
उनमें से प्रत्येक के लिए ( नहीं (बच्चे + बच्चे) और अगले तक इसलिए जादू यदि आप अन्य प्रासंगिक अंतर आपके संस्करण और दान ए के संस्करण के बीच में कुछ छोटे अंतर हैं: सबसे पहले, वह केवल एक ही वर्ग के साथ काम करता है, क्योंकि वह चयनकर्ता के रूप में दूसरे, वह इसे $ ('li.child: नहीं (li.child + li.child)') < / /> हर पहले बच्चे को चुनता है (एक बच्चा जो किसी अन्य बच्चे से नहीं चल रहा है)।
.each (function () {
), इसके सब इकट्ठा करें भावी बहन ( और स्वयं
) सहित अगले माता-पिता ( अगली युग में ('li.parent')
), और उस संग्रह को एक ul
में लपेटें ( wrapAll ('& lt; ul & gt;')
)। नहीं (li.child + li.child)
के संयोजन में है (जो प्रत्येक 'समूह' का पहला बच्चा चुनता है), और अगलीअंत तक
विधि (जो चयन करता है अगले माता-पिता तक के बाद के सभी बच्चे)। नहीं हटाते हैं (.. .. .. ..)
, आप सभी बच्चों को मिलेगा और उनके बाद के भाई बहन, जिसके परिणामस्वरूप ओवरलैपिंग ग्रुप होते हैं जो सभी लिपटे होते हैं। यह आपके HTML को गंभीरता से खराब करता है। नहीं (li.child)
का उपयोग करता है, इसलिए मूल रूप से जो कोई भी बच्चा नहीं है वह माता-पिता को माना जाता है & lt; li & gt; & lt; ul & gt;
के बजाय बस & lt; ul & gt;
के रूप में लपेटता है। यह समझ में आता है, क्योंकि आइटम पहले से ही एक सूची में हैं माता-पिता सूची को वैध रखने के लिए बच्चों के संग्रह को एक li
में लपेटा जाना चाहिए li
के अलावा अन्य तत्व ul
तत्वों के प्रत्यक्ष बच्चों के रूप में मान्य नहीं हैं आपका कोड माता-पिता ul
के अंदर एक ul
डालता है, तकनीकी रूप से HTML अवैध बना रहा है ब्राउज़र संभवत: निहित li
को जोड़कर यह आपके लिए ठीक कर देगा।
No comments:
Post a Comment