Как использовать Xpath в Yahoo! Виджеты для обхода дерева?
Я создаю Yahoo! Виджет и сделал это раньше без каких-либо проблем (создание виджета). Я получаю документ XML через веб-ссылку и хочу, чтобы все узлы вводились в дерево. Я делаю это:
var request = new XMLHttpRequest();
request.open( "GET", url, false );
request.send();
if ( request.status == 200 )
{
doc = request.responseXML;
tree = doc.evaluate("/lfm");
status = tree.item(0).getAttribute("status")
if(status == "ok")
{
print ("status is ok!");
tracks = doc.evaluate("/lfm/recenttracks[1]/track");
for(i=0;i<tracks.length;i++)
{
artist = tracks.item(i).firstChild.firstChild.data;
}
}
}
}
Таким образом, вы можете получить художника узла из дерева. есть проблема, если вы хотите иметь следующего брата или сестру. Вы должны позвонить
tracks.item(i).firstChild.nextSibling.firstChild.data;
tracks.item(i).firstChild.nextSibling.nextSibling.firstChild.data;
tracks.item(i).firstChild.nextSibling.nextSibling.nextSibling.firstChild.data;
чтобы сделать это. Узел рядом с ним добавляет 'next sibling' и так далее. Я не хочу продолжать добавлять эти узлы и думал, что можно было бы использовать childNodes[i] следующим образом:
artist = tracks.item(i).childNodes[0].firstChild.data;
nextitem = tracks.item(i).childNodes[1].firstChild.data;
это не работает все же. он возвращает "childNodes[0] не имеет свойств" любым способом, которым я его использую. Теперь я думаю, что в Xpath есть способ сделать это в цикле for:
name = doc.evaluate("string(/lfm/recenttracks[1]/track["+i+"]/name)");
print(name);
othernode = doc.evaluate("string(/lfm/recenttracks[1]/track["+i+"]/album)");
print(othernode);
а затем увеличивая я для следующего трека. но почему-то это возвращает только один элемент. он не получает больше элементов для -loop. I-1 тоже не работает.
Кто-нибудь знает, как использовать выражение Xpath с моим значением i, чтобы выбрать узел, а затем получить подузлы для каждого суперузла? Для каждого трека я хочу получить исполнителя, имя, поток, mbid, альбом, URL, изображение (маленькое), изображение (среднее), изображение (большое) и дату.
мой xml файл выглядит так:
<lfm status="ok">
<recenttracks user="xaddict">
<track nowplaying="true">
<artist mbid="f5b8ea5f-c269-45dd-9936-1fedf3c56851">The Presets</artist>
<name>Girl (You Chew My Mind Up)</name>
<streamable>1</streamable>
<mbid></mbid>
<album mbid="b150d099-b0f3-4feb-9a05-34e693c6dd24">Beams</album>
<url>http://www.last.fm/music/The+Presets/_/Girl+%28You+Chew+My+Mind+Up%29</url>
<image size="small">http://userserve-ak.last.fm/serve/34s/8696437.jpg</image>
<image size="medium">http://userserve-ak.last.fm/serve/64s/8696437.jpg</image>
<image size="large">http://userserve-ak.last.fm/serve/126/8696437.jpg</image>
<date uts="1236440600">7 Mar 2009, 15:43</date>
</track>
<track >
<artist mbid="f5b8ea5f-c269-45dd-9936-1fedf3c56851">The Presets</artist>
<name>Get Outta Here</name>
<streamable>1</streamable>
<mbid></mbid>
<album mbid="0469956f-d895-4120-8ec5-29ad41b9e2fd">Blow Up</album>
<url>http://www.last.fm/music/The+Presets/_/Get+Outta+Here</url>
<image size="small">http://userserve-ak.last.fm/serve/34s/20923179.png</image>
<image size="medium">http://userserve-ak.last.fm/serve/64s/20923179.png</image>
<image size="large">http://userserve-ak.last.fm/serve/126/20923179.png</image>
<date uts="1236440242">7 Mar 2009, 15:37</date>
</track>
</recenttracks>
</lfm>
3 ответа
Полностью способ Xpath делает это с помощью преобразования строк в Xpath. Я уже разместил этот код в качестве ответа на другой вопрос и сделаю это снова. Я очень рад, что узнал об этом способе ведения дел.
var entries = xmlDoc.evaluate("lfm/recenttracks/track");
var length = entries.length;
for(var i = 0; i < length; i++) {
var entry = entries.item(i);
var obj = {
artist: entry.evaluate("string(artist)"),
name: entry.evaluate("string(name)"),
url: entry.evaluate("string(url)"),
image: entry.evaluate("string(image[@size='medium'])")
};
posts[i] = obj;
}
Попробуй это
for (var i = 0; i < xmlDoc.getElementsByTagName('track').length; i++)
{
alert(xmlDoc.getElementsByTagName('track')[i].getElementsByTagName('name')[0].childNodes[0].nodeValue);
}
Если вы хотите использовать xpath, вы также можете попробовать следующее решение.
var s = xmlDoc.evaluate( '//track' ,xmlDoc, null, XPathResult.ANY_TYPE, null );
var track = s.iterateNext();
while (track)
{
alert(track.getElementsByTagName('name')[0].textContent );
track = s.iterateNext();
}
Можете ли вы опубликовать соответствующий фрагмент XML? Мы смотрим на ваш код, который его анализирует, но если бы у нас был сам XML, было бы проще обработать запрос Xpath. Самым полезным будет бит, в котором есть такие элементы, как
<lfm>
<recenttracks>
<track>
<album>
так далее