使用XML Parser从用户那里获取最近的YouTube视频

时间:2012-02-29 19:02:37

标签: javascript xml api parsing youtube

哟!

因此,我的目标是获取由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);
}

这是一个问题。另一个,我想,是如何使用解析器 - 我已经阅读但仍然不明白。你能解释它是如何工作的吗?我知道我搜索某个标签 - 然后它会给我一个该标签中的元素列表。但是如何浏览该列表呢?

干杯,谢谢你的时间

西蒙

1 个答案:

答案 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;