尽管使用了 PHP DOM 函数很长一段时间,但原始发帖者 (OP) 表示很难理解其功能。他们提供了一个 XML 示例并描述了他们遇到的两个具体问题:
OP 使用 setIdAttribute 函数为页面元素设置 ID,以防止加载时重复到树里。然而,他们在尝试使用 getElementById 检索这些 ID 时遇到了挑战。
解决方案:
要解决此问题,建议 OP 使用 xml:id 属性而不是传统的 id 属性。这种方法不需要 DTD 或 Schema,并且允许 DOM 无需验证即可识别 ID 属性。
为了最小化加载的数据,OP 最初创建了 ID 属性在页面上。然而,由于 getElementById 的限制,他们改用 XPath 来检索必要的信息。
解决方案:
而不是依赖 getElementById,他们声称这样做无法在其平台上正常工作,OP 可以利用 XPath 来查询特定页面及其子元素的 XML。该解决方案提供了一种更高效、更通用的方法来检索所需数据。
示例:
使用 XPath 检索 ID 为“1”的特定页面的所有产品:
<code class="php">$xpath->query('/pages/page[@id="1"]/products');</code>
为了回复评论,OP 提供了更详细的解释:
使用 XML:ID 属性:
使用 xml:id 属性设置 ID 属性时,DOM 实例无需 DTD 或 Schema 即可识别它。这是由 W3C 定义的,独立于平台或 libxml 版本工作。
非命名空间 ID 属性的限制:
如果在没有 xml 的情况下设置 ID 属性:id 命名空间,DOM 会将其视为常规属性。要将其识别为 ID 属性,必须指定 DTD 或架构,并且必须根据它验证 XML。
XPath 仍然是查询 XML 文档的通用且可靠的方法,尤其是在涉及 ID 属性时。它消除了对 getElementById 的依赖,并提供了根据各种条件检索特定元素的灵活性。
以上是如何掌握 PHP DOM XML 解析:简化 ID 管理和页面加载的详细内容。更多信息请关注PHP中文网其他相关文章!