我试图通过使用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"
,它可以正常工作。
当标签中包含带有:
的属性时,为什么标签查找失败?
答案 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'));