Java脚本XML Reader返回空的HTMLCollection

时间:2018-08-30 06:44:41

标签: javascript xml domparser

我试图通过使用DOMParser解析xml来获取所有标题标签。以下是我的代码,

function fetchHeaders(text){
    text = '<body><custom h:f="val"><h2></h2></custom></body>';
    var parser = new DOMParser();
    var xmlDoc = parser.parseFromString(text,"text/xml");
    console.log(xmlDoc.getElementsByTagName('h2'));
}

返回一个空的HTML集合,而不是h2标签。

没有属性h:f="val",它可以正常工作。

当标签中包含带有:的属性时,为什么标签查找失败?

1 个答案:

答案 0 :(得分:1)

该xml字符串包含名称空间(:h),但不能解析为任何内容。

var xmlString = '<body xmlns:h="http://www.w3.org/1999/xhtml"><custom h:f="val"><h2></h2></custom></body>';
var parser = new DOMParser();
var xmlDoc = parser.parseFromString(xmlString,"text/xml");
console.log(xmlDoc.getElementsByTagName('h2'));

或者,您可以替换所有出现的名称空间:h。

var xmlString = '<body><custom h:f="val"><h2></h2></custom></body>';
xmlString = xmlString.replace(/h:/g, "");  
var parser = new DOMParser();
var xmlDoc = parser.parseFromString(xmlString,"text/xml");
console.log(xmlDoc.getElementsByTagName('h2'));