如何使用E4X和Flex / Flash ActionScript提取"For"属性的值



我有一个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)

最新更新