
1. 问题背景:DOMDocument 与非标准属性的冲突
在现代 web 开发中,尤其是在使用 vue.js、angular 等前端框架时,html 元素上经常会包含一些非标准属性,例如 @click、@autocomplete:change 等,它们用于事件绑定或数据绑定。php 的 domdocument 扩展是一个强大的 html/xml 解析器,但它在处理这些非标准属性时,可能会因为底层的 xml 解析规则而将其移除。
DOMDocument 默认遵循 XML 规范,而 @ 符号在 XML 中通常用于表示命名空间前缀。当 DOMDocument 遇到 role="tab" @click="activeType=listingType" 这样的结构时,它可能无法识别 @click 为一个有效的属性名,或将其误判为命名空间声明的错误部分,最终导致这些属性在解析和保存过程中被悄然删除。
以下是一个典型的示例,展示了 DOMDocument 移除 @click 属性的行为: