菜单
×
   ❮     
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS R TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI GO KOTLIN SASS VUE DSA GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE
     ❯   

XML 教程

XML 首页 XML 简介 XML 如何使用 XML 树 XML 语法 XML 元素 XML 属性 XML 命名空间 XML 显示 XML HttpRequest XML 解析器 XML DOM XML XPath XML XSLT XML XQuery XML XLink XML 验证器 XML DTD XML Schema XML 服务器 XML 示例 XML 测验 XML 证书

XML AJAX

AJAX Introduction AJAX XMLHttp AJAX Request AJAX Response AJAX XML File AJAX PHP AJAX ASP AJAX Database AJAX Applications AJAX Examples

XML DOM

DOM Introduction DOM Nodes DOM Accessing DOM Node Info DOM Node List DOM Traversing DOM Navigating DOM Get Values DOM Change Nodes DOM Remove Nodes DOM Replace Nodes DOM Create Nodes DOM Add Nodes DOM Clone Nodes DOM Examples

XPath 教程

XPath Introduction XPath Nodes XPath Syntax XPath Axes XPath Operators XPath Examples

XSLT 教程

XSLT Introduction XSL Languages XSLT Transform XSLT <template> XSLT <value-of> XSLT <for-each> XSLT <sort> XSLT <if> XSLT <choose> XSLT Apply XSLT on the Client XSLT on the Server XSLT Edit XML XSLT Examples

XQuery 教程

XQuery Introduction XQuery Example XQuery FLWOR XQuery HTML XQuery Terms XQuery Syntax XQuery Add XQuery Select XQuery Functions

XML DTD

DTD Introduction DTD Building Blocks DTD Elements DTD Attributes DTD Elements vs Attr DTD Entities DTD Examples

XSD Schema

XSD 简介 XSD 如何使用 XSD <schema> XSD 元素 XSD 属性 XSD 限制 XSD 复杂元素 XSD 空 XSD 仅元素 XSD 仅文本 XSD 混合 XSD 指示符 XSD <any> XSD <anyAttribute> XSD 替换 XSD 示例

XSD Data Types

XSD String XSD Date/Time XSD Numeric XSD Misc XSD Reference

Web Services

XML Services XML WSDL XML SOAP XML RDF XML RSS

参考手册

DOM 节点类型 DOM 节点 DOM 节点列表 DOM NamedNodeMap DOM 文档 DOM 元素 DOM 属性 DOM 文本 DOM CDATA DOM 注释 DOM XMLHttpRequest DOM 解析器 XSLT 元素 XSLT/XPath 函数

XPath 语法


XPath 使用路径表达式在 XML 文档中选择节点或节点集。通过遵循路径或步骤来选择节点。


XML 示例文档

我们将在下面的示例中使用以下 XML 文档。

<?xml version="1.0" encoding="UTF-8"?>

<bookstore>

<book>
  <title lang="en">哈利波特</title>
  <price>29.99</price>
</book>

<book>
  <title lang="en">学习 XML</title>
  <price>39.95</price>
</book>

</bookstore>

选择节点

XPath 使用路径表达式在 XML 文档中选择节点。通过遵循路径或步骤来选择节点。最常用的路径表达式如下所示:

表达式 描述
nodename 选择名称为 "nodename" 的所有节点
/ 从根节点开始选择
// 从当前节点开始选择文档中与选择匹配的节点,无论它们在何处
. 选择当前节点
.. 选择当前节点的父节点
@ 选择属性

下表中列出了一些路径表达式及其结果:

路径表达式 结果
bookstore 选择名称为 "bookstore" 的所有节点
/bookstore 选择根元素 bookstore

注意: 如果路径以斜杠 ( / ) 开头,则它始终表示到元素的绝对路径!

bookstore/book 选择 bookstore 的所有子 book 元素
//book 选择文档中所有 book 元素,无论它们在何处
bookstore//book 选择 bookstore 元素的所有后代 book 元素,无论它们在 bookstore 元素下何处
//@lang 选择所有名为 lang 的属性


谓词

谓词用于查找特定节点或包含特定值的节点。

谓词始终嵌入方括号中。

下表中列出了一些带谓词的路径表达式及其结果:

路径表达式 结果
/bookstore/book[1] 选择 bookstore 元素的第一个子 book 元素。

注意: 在 IE 5,6,7,8,9 中,第一个节点是 [0],但根据 W3C,它是 [1]。为了解决 IE 中的这个问题,将 SelectionLanguage 设置为 XPath

在 JavaScript 中:xml.setProperty("SelectionLanguage","XPath");
/bookstore/book[last()] 选择 bookstore 元素的最后一个子 book 元素
/bookstore/book[last()-1] 选择 bookstore 元素的倒数第二个子 book 元素
/bookstore/book[position()<3] 选择 bookstore 元素的前两个子 book 元素
//title[@lang] 选择所有具有名为 lang 的属性的 title 元素
//title[@lang='en'] 选择所有具有 "lang" 属性且值为 "en" 的 title 元素
/bookstore/book[price>35.00] 选择 bookstore 元素中所有价格元素值大于 35.00 的 book 元素
/bookstore/book[price>35.00]/title 选择 bookstore 元素中所有价格元素值大于 35.00 的 book 元素的 title 元素

选择未知节点

XPath 通配符可用于选择未知的 XML 节点。

通配符 描述
* 匹配任何元素节点
@* 匹配任何属性节点
node() 匹配任何类型的任何节点

下表中列出了一些路径表达式及其结果:

路径表达式 结果
/bookstore/* 选择 bookstore 元素的所有子元素节点
//* 选择文档中的所有元素
//title[@*] 选择所有至少具有一个任何类型属性的 title 元素

选择多个路径

通过在 XPath 表达式中使用 | 运算符,您可以选择多个路径。

下表中列出了一些路径表达式及其结果:

路径表达式 结果
//book/title | //book/price 选择所有 book 元素的所有 title 和 price 元素
//title | //price 选择文档中的所有 title 和 price 元素
/bookstore/book/title | //price 选择 bookstore 元素的 book 元素的所有 title 元素以及文档中的所有 price 元素

×

联系销售

如果您想将 W3Schools 服务用于教育机构、团队或企业,请发送电子邮件给我们
sales@w3schools.com

报告错误

如果您想报告错误,或想提出建议,请发送电子邮件给我们
help@w3schools.com

W3Schools 经过优化,旨在方便学习和培训。示例可能经过简化,以提高阅读和学习体验。教程、参考资料和示例会不断审查,以避免错误,但我们无法保证所有内容的完全正确性。使用 W3Schools 即表示您已阅读并接受我们的使用条款Cookie 和隐私政策

版权所有 1999-2024 Refsnes Data。保留所有权利。W3Schools 由 W3.CSS 提供支持