哟!
因此,我的目标是获取由youtube用户上传的三个最新视频,在本例中为“aosjeff”。我知道我可以向youtube发送一个“获取”请求,然后使用XML解析器解析该xml文档(我不能使用php,我正在使用的网站构建网站不会让我),我正在尝试在这里使用一些代码将“get”请求的结果存储在javascript中的字符串中,以便我可以解析它们。但每当我运行此代码并调用“alert(txt)”时,只返回字符串“[object document]”,而不是xml数据。这是代码:
function getVideoHTML()
{
if (window.XMLHttpRequest)
{// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp=new XMLHttpRequest();
}
else
{// code for IE6, IE5
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","https://gdata.youtube.com/feeds/api/users/aosjeff/uploads",false);
xmlhttp.send();
txt = xmlhttp.responseXML;
if (window.DOMParser)
{
parser=new DOMParser();
xmlDoc=parser.parseFromString(txt,"text/xml");
}
else // Internet Explorer
{
xmlDoc=new ActiveXObject("Microsoft.XMLDOM");
xmlDoc.async=false;
xmlDoc.loadXML(txt);
}
//document.getElementById("to").innerHTML=
//xmlDoc.getElementsByTagName("to")[0].childNodes[0].nodeValue;
//document.getElementById("from").innerHTML=
//xmlDoc.getElementsByTagName("from")[0].childNodes[0].nodeValue;
//document.getElementById("message").innerHTML=
//xmlDoc.getElementsByTagName("body")[0].childNodes[0].nodeValue;
alert(txt);
}
这是一个问题。另一个,我想,是如何使用解析器 - 我已经阅读但仍然不明白。你能解释它是如何工作的吗?我知道我搜索某个标签 - 然后它会给我一个该标签中的元素列表。但是如何浏览该列表呢?
干杯,谢谢你的时间
西蒙
答案 0 :(得分:2)
您不必使用DOMParser解析responseXML
属性,因为它已经是XML对象。使用string-to-xml解析方法(推荐),或将responseXML
属性替换为responseText
。
txt = xmlhttp.responseXML; // <-- This is a XML document object
if (window.DOMParser) {
parser = new DOMParser();
xmlDoc=parser.parseFromString(txt,"text/xml"); // <--- txt should be a string
} else {....}
应该是:
xmlDoc = xmlhttp.responseXML;