QML处理xml使用的是XmlListModel + XmlRole,基本的操作可以参考官方文档,说的很清楚。
使用query查询目标节点时,如果包含 namespace,如“a:book”,则会查询到null。
如果声明的是默认命名空间,如
<xml_api_reply xmlns="http://duino.com/" version="1">
需要如下处理:
XmlListModel {
source: "http://mysite.com/feed.xml"
query: "/feed/entry"
<strong><span style="color:#ff0000;">namespaceDeclarations: "declare default element namespace 'http://duino.com/';"</span></strong>
XmlRole { name: "title"; query: "title/string()" }
}
<rss xmlns:yweather="http://xml.weather.yahoo.com/ns/rss/1.0" version="2.0">
......
<yweather:forecast day="Tue" date="24 Feb 2015" low="11" high="17" text="Partly Cloudy" code="30"/>
......
需要如下处理:
<span style="white-space:pre"> </span>XmlListModel {
<span style="white-space:pre"> </span>id: weatherModelForecast
source: "http://weather.yahooapis.com/forecastrss?w=2133704&u=c"
query: "/rss/channel/item/yweather:forecast"
<strong><span style="color:#ff0000;">namespaceDeclarations: "declare namespace yweather='http://xml.weather.yahoo.com/ns/rss/1.0';"</span></strong>
XmlRole { name: "day"; query: "@day/string()" }
XmlRole { name: "date"; query: "@date/string()" }
XmlRole { name: "low"; query: "@low/string()" }
XmlRole { name: "high"; query: "@high/string()" }
XmlRole { name: "text"; query: "@text/string()" }
}
query才可以查询到相应的数据。
参考文档:https://msdn.microsoft.com/zh-cn/library/ms190945(v=sql.105).aspx