js 将XML字符串解析成XML文档 --- attribute construct error--- 空白字符与空格问题

时间:2023-03-08 16:48:26
js 将XML字符串解析成XML文档  --- attribute construct error--- 空白字符与空格问题

最近在做xml在线编辑器,遇到一个字符串解析成xml文档的问题,记录一下。

原始xml内容读取自xml文档

<label class="test" id="label1"/>

编辑之后的xml内容

<" test="test"/>

在处理在线编辑的过程中使用的是dom range的相关处理,在使用domparser将xml字符串解析成xml文档,原始内容可以成功解析,编辑之后的内容解析遇到了parsererror  attribute construct error(Chrome出错,Firefox可以)。

从字符串来看看不出任何错误,猜测是特殊字符引起,但是我所编辑的内容又不涉及到通常所提到的<&等字符。最终通过比较encodeURI结果发现:原始xml内容属性之间隔得是空格,而我编辑时输入的空格实际是空白字符,所以导致解析失败

编码: 空格%20    空白字符 %C2%A0

解决方法是在用domparser之前先将字符串的空白字符替换成空格再解析,亲测有效。