扫码一下
查看教程更方便
内建的 dom 解析器使在 php 中处理 xml 文档成为可能。
w3c dom 提供了针对 html 和 xml 文档的标准对象集,以及用于访问和操作这些文档的标准接口。
w3c dom 被分为不同的部分(core, xml 和 html)和不同的级别(dom level 1/2/3):
如需读取和更新 - 创建和处理 - 一个 xml 文档,您需要 xml 解析器。
有两种基本的 xml 解析器类型:
dom 解析器是基于树的解析器。
请看下面的 xml 文档片段:
jani
xml dom 把上面的 xml 视为一个树形结构:
dom xml 解析器函数是 php 核心的组成部分。无需安装就可以使用这些函数。
下面的 xml 文件将应用在我们的示例中:
tove
jani
reminder
don't forget me this weekend!
我们需要初始化 xml 解析器,加载 xml,并把它输出:
load("note.xml");
print $xmldoc->savexml();
?>
以上代码将输出:
tovejanireminder don't forget me this weekend!
如果您在浏览器窗口中查看源代码,会看到下面的 html:
tove
jani
reminder
don't forget me this weekend!
上面的实例创建了一个 domdocument-object,并把 "note.xml" 中的 xml 载入这个文档对象中。
savexml() 函数把内部 xml 文档放入一个字符串,这样我们就可以输出它。
我们要初始化 xml 解析器,加载 xml,并遍历
元素的所有元素:
load("note.xml");
$x = $xmldoc->documentelement;
foreach ($x->childnodes as $item)
{
print $item->nodename . " = " . $item->nodevalue . "
";
}
?>
以上代码将输出:
#text =
to = tove
#text =
from = jani
#text =
heading = reminder
#text =
body = don't forget me this weekend!
#text =
在上面的实例中,您看到了每个元素之间存在空的文本节点。
当 xml 生成时,它通常会在节点之间包含空白。xml dom 解析器把它们当作普通的元素,如果您不注意它们,有时会产生问题。