SimpleXML 读取属性需用 ->attributes() 并强制转字符串,命名空间须用 children() 或 attributes() 指定前缀或 URI;添加属性用方括号赋值,无法原生增删命名空间。
SimpleXML 是 PHP 处理 XML 最轻量、最常用的方式,但它对属性和命名空间的支持比较隐式——不直接暴露为数组或对象属性,需要特定方法访问。
SimpleXML 不会把属性自动转成对象属性,必须用 ->attributes() 方法显式获取。返回的是一个 SimpleXMLIterator 对象(可遍历),本质是属性名到值的映射。
$elem->attributes() 获取全部属性,再通过索引或键名访问,如 (string)$elem->attributes()['id']
(string))才能安全使用,否则可能触发警告或意外对象行为$elem->attributes()['data-role']
命名空间不能靠点号访问,必须先注册前缀(或用 URI),再用 ->children() 或 ->attributes() 指定命名空间参数。
$xml->getNamespaces() 查看文档声明了哪些命名空间(返回关联数组:前缀 ⇒ URI)$elem->children('ns', true) 进入指定命名空间的子元素,其中 'ns' 是前缀,true 表示按前缀查找;也可传 URI 字符串代替前缀$elem->attributes('ns', true) 获取该命名空间下的属性xmlns="http://example.com/ns")需用空字符串 '' 作为前缀参数,或用 URI 显式指定SimpleXML 允许动态添加属性,但不支持直接设置命名空间声明(如 xmlns:ns="..."),需在加载时确保 XML 结构完整,或改用 DOMDocument 做更底层操作。
$elem['newattr'] = 'value'; —— 注意是方括号赋值,不是箭头$elem['existing
'] = 'newval';
dom_import_simplexml() 转为 DOM 节点后操作asXML() 输出属性和命名空间是 SimpleXML 最易出错的环节,尤其在混合命名空间或解析第三方 API 返回时。
attributes() 和 children() 返回是否为空对象,避免调用方法时报错isset($elem['attr']) 更可靠asXML() 验证结果,注意它不会自动补全未显式声明的命名空间前缀