XML DOM compareDocumentPosition() 方法

定义和用法

compareDocumentPosition() 方法根据文档顺序将当前节点的文档位置与指定节点进行比较。

语法

elementNode.compareDocumentPostition(node)
参数 描述
node 必需。规定与当前节点进行比较的节点。

实例

下面的代码将 "books.xml" 加载到 xmlDoc 中,并比较 DOM 层次结构中两个节点(第一个和第三个 <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 x = xmlDoc.getElementsByTagName('book')[0];
    var y = xmlDoc.getElementsByTagName('book')[2];
    document.getElementById("demo").innerHTML =
    x.compareDocumentPosition(y);
}

亲自试一试

大多数浏览器会将空白或新行视为文本节点,IE 9 及更早版本不会。因此,在上面的例子中,大多数浏览器将输出 4,而 IE 9 及更早版本将输出 2。

如需了解有关浏览器之间差异的更多信息,请访问 XML DOM 教程中的 DOM 浏览器章节。