Μεθόδος insertBefore() του XML DOM

Ορισμός και χρήση

insertBefore() Η μεθόδος εισάγει νέο υποκείμενο πριν από το καθορισμένο υποκείμενο του τρέχοντος κόμβου.

Σημείωση:Αν το newchild υπάρχει ήδη στο δέντρο, τότε θα αφαιρεθεί πρώτα.

Γραμματική

nodeObject.insertBefore(newchild,existingnode,

)

) Περιγραφή
newchild Απαιτείται. Οντότητα Node. Το νέο υποκείμενο που πρέπει να εισαχθεί.
existingnode

Απαιτείται. Οντότητα Node. Η οντότητα που πρέπει να εισαχθεί πριν από το νέο υποκείμενο.

Αν το υπάρχον κελί είναι κενό, το νέο υποκείμενο εισάγεται στο τέλος της λίστας υποκειμένων.

Τεχνικά λεπτομέρειες

Έκδοση DOM: Αποτελεσματικότητα επιπέδου Core Level 1 Node Object. Αναθεωρείται στο DOM Level 3.
Αποτελεσματικότητα: Οντότητα Node. Ο κόμβος που εισάγεται.

Παράδειγμα

Η παρακάτω κώδικας φορτώνει το "books.xml", δημιουργεί ένα νέο <book> κελί και το εισάγει πριν από το τελευταίο <book> κελί:

var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function() {
   if (this.readyState == 4 && this.status == 200) {
       myFunction(this);
   }
};
xhttp.open("GET", "books.xml", true);
xhttp.send();
function myFunction(xml) {
    var xmlDoc = xml.responseXML;
    var newNode = xmlDoc.createElement("book");
    var x = xmlDoc.documentElement;
    var y = xmlDoc.getElementsByTagName("book");
    document.getElementById("demo").innerHTML =
    "Βιβλιογραφικά στοιχεία πριν: " + y.length + "<br>";
    x.insertBefore(newNode, y[3]);
    document.getElementById("demo").innerHTML +=
    "Book elements after: " + y.length;
}

亲自试一试

浏览器支持

Chrome Edge Firefox Safari Opera
Chrome Edge Firefox Safari Opera
支持 支持 支持 支持 支持

所有主流浏览器都支持 insertBefore() 方法。