我正在尝试解析一个非常简单的XML文件。
我需要获取一个包含URL的标记元素。 XML文件中的标记是sURL。
我尝试使用下面的代码,但它没有返回URL的文本值。 我不知道我做错了什么,为什么它不起作用。
var url = "http://example.com/data.xml"; //xml resource url
var xhr = Titanium.Network.createHTTPClient();
xhr.onload = function() {
var doc = this.responseXML.documentElement;
var myURL = doc.getElementsByTagName("sURL");
Ti.API.info(myURL);
};
xhr.onerror = function(e) {
alert('Network error '+e.error);
};
xhr.open('GET',url);
xhr.send();
XML:
<rss version="2.0">
<channel>
<title>test</title>
<description>
</description>
<time>test</time>
<time2>test</time2>
<sURL>https://example.com</sURL>
<item>
<title>test</title>
<broadcast>test</broadcast>
<time>17:00</time>
<time2>14:00</time2>
</item>
<item>
<title>test</title>
<broadcast>test</broadcast>
<time>19:00</time>
<time2>16:00</time2>
</item>
<item>
<title>test</title>
<broadcast>test</broadcast>
<time>21:00</time>
<time2>18:00</time2>
</item>
<item>
<title>test</title>
<broadcast>test</broadcast>
<time>23:00</time>
<time2>20:00</time2>
</item>
<item>
<title>test</title>
<broadcast/>
<time>01:00</time>
<time2>22:00</time2>
</item>
</channel>
</rss>
答案 0 :(得分:1)
检查以下代码以获取sURL的第一项,如果它没有工作共享xml文件
var url = "https://gist.githubusercontent.com/kassemitani/e25ab8654a4914a7e19edaecd7cb5460/raw/3aad56a246edc8e4dd42b1255c602f8676434a8f/test.xml"; //xml resource url
var xhr = Titanium.Network.createHTTPClient();
xhr.onload = function() {
var doc = this.responseXML.documentElement;
var myURL = doc.getElementsByTagName("sURL").item(0).textContent;
Ti.API.info(myURL);
};
xhr.onerror = function(e) {
alert('Network error '+e.error);
};
xhr.open('GET',url);
xhr.send();