我有一个返回xml数据的http服务。
<mx:HTTPService id="httpService" url="data/Software.xml" resultFormat="e4x" result="httpResult_handler(event)" fault="Alert.show('XML Data Error')" />
我还有一个使用返回数据的数据网格,并将它传递给完美的渲染器。
<mx:DataGrid id="myDG"
dataProvider="{httpService.lastResult.item}"
headerHeight="0"
editable="false"
width="100%" height="100%"
rowHeight="50"
itemClick="switchView(myDG.selectedItem.name);">
<mx:columns>
<mx:DataGridColumn itemRenderer="com.xd.components.renderers.SoftwareListRenderer" />
</mx:columns>
</mx:DataGrid>
对于xml数据中的每个结果,我都有一些代码可以创建一个新的panel()
和渲染器。
private function viewstack_addChild(name:String):void {
var p:Panel = new Panel();
p.id = name;
p.name = name;
p.title = name;
p.percentWidth = 100;
p.percentHeight = 100;
var randColor:uint = Math.random() * 0xFFFFFF;
p.setStyle("backgroundColor", randColor);
var pR:PageListRenderer = new PageListRenderer();
var data:Object;
//Do something to get the data to be displayed;
pR.data = PageListRenderer;
p.addChild(pR);
myViewStack.addChild(p);
}
但是,我无法在此渲染器中使用与数据网格渲染器中相同的{data.name}
。相反,我为每个字段“未定义”...我如何将{httpService.lastResult.item}
传递给页面渲染器呢?
编辑:改变了..
这是httpservice结果处理程序。
private function httpResult_handler(evt:ResultEvent):void {
if (evt.result.software.item) {
data = XML(evt.result).descendants("item");
var item:Object = data;
for each(item in data) {
viewstack_addChild(item.name);
}
}
}
我也试过..
private function httpResult_handler(evt:ResultEvent):void {
if (evt.result.software.item) {
data = httpService.lastResult.item;
var item:Object = data;
for each(item in data) {
viewstack_addChild(item.name);
}
}
}
我还更改了pR.data = data
功能中的viewstack_addChild
。
我仍然在datagrid中获取信息,并且我在每个页面上获取数据但是每个页面都有相同的信息(第一个结果)而不是每个页面的每个结果......
答案 0 :(得分:0)
我认为问题在于您将数据设置为PageListRenderer,它看起来像一个类而不是您想要的数据。