您的位置:首页 > 其它

Flex中为控件使用远程XML数据

2010-03-30 15:45 585 查看
通过HTTPService获取XML数据

在浏览器中输入:http://www.flexgrocer.com/units.xml,可以看到XML格式文档,将使用HTTPService获取该xml中的数据。
打开前面完成的DataEntry.mxml文件,代码如下
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml"
layout="absolute">
<mx:Model id="prodModel">
<groceries>
<catName>Dairy</catName>
<prodName>Milk</prodName>
<imageName>assets/dairy_milk.jpg</imageName>
<cost>1.20</cost>
<listPrice>1.99</listPrice>
<isOrganic>true</isOrganic>
<isLowFat>true</isLowFat>
<description>Direct from California where cows are happiest!</description>
</groceries>
</mx:Model>
<mx:Script>
<!--[CDATA[
import flash.net.FileReference;
public function fileBrowse():void{
var myFileRef:FileReferenceList = new FileReferenceList();
myFileRef.browse();
}
]]-->
</mx:Script>
<mx:Form>
<mx:FormHeading label="{prodModel.catName}"/>
<mx:FormItem label="Product Name">
<mx:TextInput id="product" text="{prodModel.prodName}"/>
</mx:FormItem>
<mx:FormItem label="ProductNameUnit" direction="horizontal">
<mx:ComboBox/>
<mx:TextInput/>
</mx:FormItem>
<mx:FormItem label="Cost">
<mx:TextInput id="cost" text="{prodModel.cost}"/>
</mx:FormItem>
<mx:FormItem label="List Price">
<mx:TextInput id="listPrice" text="{prodModel.listPrice}"/>
</mx:FormItem>
<mx:FormItem label="Description">
<mx:TextInput id="Description" text="{prodModel.description}"/>
</mx:FormItem>
<mx:FormItem label="Organic">
<mx:CheckBox id="isOrganic" selected="{prodModel.isOrganic}"/>
</mx:FormItem>
<mx:FormItem label="Is Low Fat?">
<mx:CheckBox id="isLowFat" selected="{prodModel.isLowFat}"/>
</mx:FormItem>
<mx:FormItem label="Image Path">
<mx:TextInput id="imageName" text="{prodModel.imageName}"/>
<mx:Button label="Browse" click="fileBrowse()"/>
</mx:FormItem>
<mx:FormItem>
<mx:HBox>
<mx:Button label="Update"/>
<mx:Button label="Delete"/>
</mx:HBox>
</mx:FormItem>
</mx:Form>

</mx:Application>
在<mx:Script>中导入两个类,代码如下
import mx.rpc.events.ResultEvent;
import utils.Util;
在<mx:Script>下面添加<mx:HTTPServic>标签,代码如下

<mx:HTTPService id="unitRPC" url="http://www.flexgrocer.com/units.xml" result="unitPRCResult(event)"/>
当id为unitRPC的httpservice执行一个send方法的时候,会从url指定的xml文件里面返回该xml的数据,成功返回以后执行unitPRCResult()函数。
在<mx:Script>里面添加unitPRCResult函数,代码如下
private function unitPRCResult(event:ResultEvent):void {
trace(event.result)
}
在<mx:Application>中添加creationComplete事件,代码如下
creationComplete="unitRPC.send()"
当页面中所有的控件创建完成以后,执行creationComplete事件,调用unitRPC的send方法,调用HTTPService。ResultEvent中的result就能得到xml中的数据。
将HTTPService数据填入ArrayCollection
ArrayCollection是将数据填入到一个列表块里面,可以作为数据的提供者。
<ms:Script>中添加相关代码,代码如下
import mx.collections.ArrayCollection;

[Bindable]
private var units:ArrayCollection = new ArrayCollection();
private function unitPRCResult(event:ResultEvent):void {
units = event.result.allUnits.unit;
}
这样就把xml中所有的unit节点数据保持到units变量里面。
在控件中使用该units,代码如下
<mx:List id="unitID" rowCount="4" dataProvider="{units}  " labelField="unitName"/>
运行结果如下



将数据填入ComboBox控件并用编程方法添加选项
同上,把远程http://www.flexgrocer.com/category.xml文件的内容保存到categories变量中,编写的代码如下
import mx.rpc.events.ResultEvent;
import mx.collections.ArrayCollection;
[Bindable]
private var categories:ArrayCollection = new ArrayCollection();
private function catHandler(event:ResultEvent):void {
categories = event.result.catalog.category;
var catObject:Object = new Object();
catObject.name = "All";
catObject.ID = 0;
categories.addItemAt(catObject, 0);
catCombo.selectedIndex = 0;
}
<mx:HTTPService id="catRPC" url="http://www.flexgrocer.com/category.xml" result="catHandler(event)"/>
creationComplete="catRPC.send()"
添加ComboBox控件,使用categories数据,代码如下
<mx:ComboBox id="catCombo" dataProvider="{categories}" labelField="name"/>
运行结果如下



在Tree控件中使用XML数据

xml数据来源: http://www.flexgrocer.com/categorizedProducts.xml
打开前面完成的DataEntry.mxml文件,添加HTTPService,代码如下
<mx:HTTPService id="prodByCatRPC" url="http://www.flexgrocer.com/categorizedProducts.xml" resultFormat="e4x"/>
添加数据绑定,代码如下
<mx:XMLListCollection id="foodColl" source="{prodByCatRPC.lastResult.category}"/>
添加tree控件,代码如下
<mx:Tree id="productTree" height="100%" dataProvider="{foodColl}" labelField="@name" change="populateForm(event)"/>
添加populateForm(event)方法,代码如下
private function populateForm(event:Event):void {
var selectedNode:Object = event.target.selectedItem;
if(selectedNode.@prodName != undefined) {
prodName.text = selectedNode.@prodName;
cost.text = selectedNode.@prodName;
listPrice.text = selectedNode.@listPrice;
description.text = selectedNode.@description;
isOrganic.selected = Util.yesNoToBoolean(selectedNode.@isOrganic);
isLowFat.selected = Util.yesNoToBoolean(selectedNode.@isLowFat);
imageName.text = selectedNode.@imageName;
} else {
resetForm();
}
}
添加resetForm()方法,代码如下
private function resetForm():void {
prodName.text = "";
cost.text = "";
listPrice.text = "";
description.text = "";
isOrganic.selected = false;
isLowFat.selected = false;
imageName.text = "";
}
此时的DataEntry.mxml文件的代码如下
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" creationComplete="prodByCatRPC.send()">
<mx:Script>
<!--[CDATA[
import flash.net.FileReference;
import mx.rpc.events.ResultEvent; import utils.Util;
public function fileBrowse():void{
var myFileRef:FileReferenceList = new FileReferenceList();
myFileRef.browse();
}

private function populateForm(event:Event):void { var selectedNode:Object = event.target.selectedItem; if(selectedNode.@prodName != undefined) { prodName.text = selectedNode.@prodName; cost.text = selectedNode.@prodName; listPrice.text = selectedNode.@listPrice; description.text = selectedNode.@description; isOrganic.selected = Util.yesNoToBoolean(selectedNode.@isOrganic); isLowFat.selected = Util.yesNoToBoolean(selectedNode.@isLowFat); imageName.text = selectedNode.@imageName; } else { resetForm(); } }
private function resetForm():void { prodName.text = ""; cost.text = ""; listPrice.text = ""; description.text = ""; isOrganic.selected = false; isLowFat.selected = false; imageName.text = ""; }]]-->
</mx:Script>
<mx:HTTPService id="prodByCatRPC" url="http://www.flexgrocer.com/categorizedProducts.xml" resultFormat="e4x"/>

<mx:XMLListCollection id="foodColl" source="{prodByCatRPC.lastResult.category}"/>

<mx:HBox>
<mx:Tree id="productTree" height="100%" dataProvider="{foodColl}" labelField="@name" change="populateForm(event)"/>
<mx:Form>
<mx:FormItem label="Product Name">
<mx:TextInput id="prodName"/>
</mx:FormItem>
<mx:FormItem label="Cost">
<mx:TextInput id="cost"/>
</mx:FormItem>
<mx:FormItem label="List Price">
<mx:TextInput id="listPrice"/>
</mx:FormItem>
<mx:FormItem label="Description">
<mx:RichTextEditor id="description" height="200"/>
</mx:FormItem>
<mx:FormItem label="Specialties">
<mx:CheckBox id="isOrganic" label="Is Organic"/>
<mx:CheckBox id="isLowFat" label="Is Low Fat"/>
</mx:FormItem>
<mx:FormItem label="Image Name" direction="horizontal">
<mx:TextInput id="imageName"/>
<mx:Button label="Browse" click="fileBrowse()"/>
</mx:FormItem>
<mx:FormItem>
<mx:HBox>
<mx:Button label="Update"/>
<mx:Button label="Delete"/>
</mx:HBox>
</mx:FormItem>
</mx:Form>
</mx:HBox>
</mx:Application>
运行结果如下



获取XML数据并将这些数据转换为自定义类型的ArrayCollection
同上利用HTTPService获取XML数据,转化方法代码如下
private function prodHandler(event:ResultEvent):void{
var prodArray:Array = new Array();
for each (var p:XML in event.result..product){
var prod:Product = new Product(
Number(p.@catID),
String(p.@prodName),
Number(p.@unitID),
Number(p.@cost),
Number(p.@listPrice),
String(p.@description),
Boolean(p.@isOrganic=="Yes"),
Boolean(p.@isLowFat=="Yes"),
String(p.@imageName));
prodArray.push(prod);
}
groceryInventory=new ArrayCollection(prodArray);
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: