Méthode XML DOM compareDocumentPosition()
❮ Objet nœud
Exemple
Le fragment de code suivant charge « books.xml » dans xmlDoc et compare le placement de deux nœuds (le premier et le troisième élément <book>) dans la hiérarchie DOM :
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 x =
xmlDoc.getElementsByTagName('book')[0];
var y =
xmlDoc.getElementsByTagName('book')[2];
document.getElementById("demo").innerHTML =
x.compareDocumentPosition(y);
}
La sortie du code ci-dessus sera :
4
La plupart des navigateurs traiteront les espaces vides ou les nouvelles lignes comme des nœuds de texte, contrairement à IE 9 et versions antérieures. Ainsi, dans l'exemple ci-dessus, la plupart des navigateurs afficheront 4, tandis qu'IE 9 et les versions antérieures afficheront 2.
Définition et utilisation
La méthode compareDocumentPosition() compare le placement de deux nœuds dans la hiérarchie DOM (document).
Prise en charge du navigateur
La méthode compareDocumentPosition() est prise en charge dans tous les principaux navigateurs.
Remarque : Internet Explorer 9 et les versions antérieures ne prennent pas en charge cette méthode.
Syntaxe
nodeObject.compareDocumentPosition(node)
Paramètres
Parameter | Type | Description |
---|---|---|
node | Node object | Required. Specifies the node to compare with the current node |
Valeur de retour
Type | Description |
---|---|
Number | A Number representing where the two nodes are positioned compared to each other. The possible return values
are:
1 - No relationship, the two nodes do not belong to the same document. 2 - The specified node precedes the current node. 4 - The specified node follows the current node. 8 - The specified node contains the current node. 16 - The specified node is contained by the current node. 32 - The specified and the current node have no common container node or the two nodes are different attributes of the same node. Note: The return value could also be a combination of values. E.g. a return value of 20 means that the specified node is contained by the current node (16) AND the specified node follows the current node (4). |
Détails techniques
Version DOM | Objet de nœud principal de niveau 3 |
---|
❮ Objet nœud