内置的DOM解析器能够处理XML文档中的PHP。
该XML DOM解析器
DOM解析器是基于树的解析器。
请看下面的XML文档部分:
<?xml version="1.0" encoding="UTF-8"?>
<from>Jani</from>
该DOM把上面的XML作为一个树型结构:
- 等级1:XML文档
- 等级2:根元素: <from>
- 等级3:文本元素: "Jani"
安装
DOM解析器函数是PHP核心的一部分。 有没有使用这些功能需要安装。
XML文件
下面的XML文件将在我们的例子中使用:
<?xml version="1.0" encoding="UTF-8"?>
<note>
<to>Tove</to>
<from>Jani</from>
<heading>Reminder</heading>
<body>Don't forget me this weekend!</body>
</note>
负载和输出XML
我们要初始化XML解析器,加载XML,并把它输出:
例
<?php
$xmlDoc = new DOMDocument();
$xmlDoc->load("note.xml");
print $xmlDoc->saveXML();
?>
代码的输出将是:
Tove Jani Reminder Don't forget me this weekend!
如果选择"View source"在浏览器窗口中,你会看到下面的HTML:
<?xml version="1.0" encoding="UTF-8"?>
<note>
<to>Tove</to>
<from>Jani</from>
<heading>Reminder</heading>
<body>Don't forget me this weekend!</body>
</note>
上面的示例创建一个DOMDocument -对象并加载从XML "note.xml"到它。
然后saveXML()函数把内部XML文档转换为字符串,这样我们就可以输出。
通过XML循环
我们要初始化XML解析器,通过的所有元素加载XML,并循环<note>元素:
例
<?php
$xmlDoc = new DOMDocument();
$xmlDoc->load("note.xml");
$x = $xmlDoc->documentElement;
foreach ($x->childNodes AS $item) {
print $item->nodeName . " = " . $item->nodeValue . "<br>";
}
?>
代码的输出将是:
#text =
to = Tove
#text =
from = Jani
#text =
heading = Reminder
#text =
body = Don't forget me this weekend!
#text =
在上面的例子中可以看出,有各元素之间的空文本节点。
当XML生成,它往往包含了节点之间的空格。 该XML DOM解析器把这些作为普通的元素,如果你不知道他们,他们有时会造成问题。
如果您想了解更多关于XML DOM,请访问我们的XML教程 。