什么是 DOM?
W3C DOM 提供了针对 HTML 和 XML 文档的标准对象集,以及用于访问和操作这些文档的标准接口。
W3C DOM 被分为不同的部分 (Core, XML 和 HTML) 和不同的级别 (DOM Level 1/2/3):
Core DOM – 为任何结构化文档定义标准的对象集
XML DOM – 为 XML 文档定义标准的对象集
HTML DOM – 为 HTML 文档定义标准的对象集
XML 解析
如需读取和更新 – 创建创建并处理 – 一个 XML 文档,您需要 XML 解析器。
有两种基本的 XML 解析器类型:
基于树的解析器:这种解析器把 XML 文档转换为树型结构。它分析整篇文档,并提供了 API 来访问树种的元素,例如文档对象模型 (DOM)。
基于事件的解析器:将 XML 文档视为一系列的事件。当某个具体的事件发生时,解析器会调用函数来处理。
DOM 解析器是基于树的解析器。
XML DOM 把 XML 视为一个树形结构:
Level 1: XML 文档
Level 2: 根元素:
Level 3: 文本元素: “John”
DOM XML 解析器函数是 PHP 核心的组成部分。无需安装就可以使用这些函数。
//示例
<?xml version="1.0" encoding="ISO-8859-1"?>
<note>
<to>George</to>
<from>John</from>
<heading>Reminder</heading>
<body>Don't forget the meeting!</body>
</note>
//加载 XML
<?php
$xmlDoc = new DOMDocument();
$xmlDoc->load("note.xml");
print $xmlDoc->saveXML();
?>
循环 XML
我们要初始化 XML 解析器,加载 XML,并循环 元素的所有元素,代码如下:
<?php
$xmlDoc = new DOMDocument();
$xmlDoc->load("note.xml");
$x = $xmlDoc->documentElement;
foreach ($x->childNodes AS $item)
{
print $item->nodeName . " = " . $item->nodeValue . "<br />";
}
?>
当 XML 生成时,它通常会在节点之间包含空白。XML DOM 解析器把它们当作普通的元素,如果您不注意它们,有时会产生问题。
如果你发现错误或有其他见解,请给 www.zhuei.cn 留言,我们会尽快更新本文!