我有一个XML文档,看起来像这个
<someRoot xmlns:ix="someURL.com">
<ns:InventoryPage Title="something">
<ns:Inventory Id="inventory">
<ns:InventoryView ID="inventoryView">
<Menu>
<ns:GridCreateActionLink Override="true" Visible="false" runat="server"/>
</Menu>
<Columns>
<ns:Column For="IncidentNo" LinkTo="default"/>
<ns:Column DisplayAs="string" For="Location"/>
<ns:Column For="DateaTimeOccur" Format="d"/>
<ns:Column For="Description"/>
<ns:Column For="Workflow.PersonResponsible" displayas="string"/>
<ns:Column For="Workflow.DueDate" Format="d"/>
<ns:Column For="DateClosed" Format="d"/>
<ns:Column DisplayAs="string" For="Workflow.Status"/>
</Columns>
</ns:InventoryView>
</ns:Inventory>
我的目标很简单,我使用AdobeFlex/AS3进行编码,并希望检索列标记中FOR属性的所有值,并将它们存储在一个数组中。
假设上面的代码在一个名为xmlObj的XML对象中,我做了以下
var xmlObj:XML = new XML(theXMLAbove);
var someXMLList:XMLList = new XMLList(xmlObj);
这就是我挠头的地方。我尝试使用e4x来检索这些值。例如
trace (xmlObj.InventoryPage.Inventory.InventoryView.Columns.column[0].(@For));
或trace(xmlObj.column[0]。(@For));
trace (someXMLList:XMLList .InventoryPage.Inventory.InventoryView.Columns.column[0].(@For));
或trace(someXMLList:XMLList.column[0]。(@For));
我一直得到一个空的XMLList。或为空。我做错了吗?希望在进行过程中得到一些帮助。谢谢-Edward
使用名称空间时需要格外小心。
var xmlObj:XML = new XML(
<ns:someRoot xmlns:ns="http://www.someURL.com/ns-someRoot">
<ns:InventoryPage Title="something">
<ns:Inventory Id="inventory">
<ns:InventoryView ID="inventoryView">
<Menu>
<ns:GridCreateActionLink Override="true" Visible="false" runat="server"/>
</Menu>
<Columns>
<ns:Column For="IncidentNo" LinkTo="default"/>
<ns:Column DisplayAs="string" For="Location"/>
<ns:Column For="DateaTimeOccur" Format="d"/>
<ns:Column For="Description"/>
<ns:Column For="Workflow.PersonResponsible" displayas="string"/>
<ns:Column For="Workflow.DueDate" Format="d"/>
<ns:Column For="DateClosed" Format="d"/>
<ns:Column DisplayAs="string" For="Workflow.Status"/>
</Columns>
</ns:InventoryView>
</ns:Inventory>
</ns:InventoryPage>
</ns:someRoot>
);
var theNameSpace:Namespace = xmlObj.namespace();
var columns:XMLList = xmlObj.theNameSpace::InventoryPage.theNameSpace::Inventory.theNameSpace::InventoryView.Columns.theNameSpace::Column;
trace(columns.@For.length() )
var somelist:XMLList = columns.@For
var arr:Array = []
for each( var someFor:String in somelist){
arr.push(someFor)
}
trace(arr)