dom - Using JavaScript insertBefore() to insert before a TextNode? -
मेरे पास HTML की तरह निम्न है:
& lt; div id = "move-me "& gt; & Lt; a href = "#" & gt; मैं एक लिंक हूं & lt; / a & gt; & Lt; / div & gt; & Lt; div id = "new-parent" & gt; कुछ सादा पाठ & Lt; / div & gt; मैं जावास्क्रिप्ट लिखने का प्रयास कर रहा हूं जो # नई-पैरेंट डिवा के अंदर पूरे # स्थानांतरित-मुझे डिवा को स्थानांतरित करने का प्रयास कर रहा है, ऊपर टेक्स्ट, ऐसा ही है:
& lt; div id = "new-parent" & gt; & Lt; div id = "move-me" & gt; & Lt; a href = "#" & gt; मैं एक लिंक हूं & lt; / a & gt; & Lt; / div & gt; कुछ सादा पाठ & Lt; / div & gt; यहां मेरे पास जावास्क्रिप्ट है:
फ़ंक्शन moveDiv () {var moveable = document.getElementById ('move-me'); Var newParent = document.getElementById ('नए-मूल'); NewParent.parentNode.insertBefore (गतिशील, newParent.firstChild); } मैं डिबग करने के लिए फायरबग का उपयोग कर रहा हूं, और मैं देख सकता हूं कि newParent.firstChild एक TextNode है, लेकिन मुझे हमेशा निम्न त्रुटि मिलती है:
नोड नहीं मिला "कोड:" 8 नएपरिप्रंट.पिंडनोड.इन्सर्ट पहले (चलने वाला, नयापरिवार.पहला बच्चा); ऐसा लगता है कि insert before को एक तत्व नोड की आवश्यकता होती है और यह पाठ नोड पर काम नहीं करेगा ... यह सही है? यदि ऐसा है, तो क्या ऐसा करने का एक और अच्छा तरीका है?
नोट : मैं पैराग्राफ टैग को शामिल करने या सफेद स्थान को हटाने के लिए HTML को संशोधित या साफ़ नहीं कर सकता।
नहीं, insert before एक पाठ नोड के साथ ठीक पहले काम करने के लिए नोड के रूप में डालें । समस्या यह है कि जिस नोड को आप पहले सम्मिलित करने का प्रयास कर रहे हैं वह उस नोड का बच्चा नहीं है, जिसमें आप सम्मिलित हैं। आपको .parentNode बिट को निकालना होगा:
newParent.insertBefore (चलने योग्य, newParent.firstChild);
Comments
Post a Comment