从appcelerator钛中的远程XML文件获取数据



我正在尝试解析一个非常简单的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>

检查以下代码以获取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();

最新更新