Apache flex 如何基于选定的阵列集合推送视图?(Flash Builder 4.6,Flex)

Apache flex 如何基于选定的阵列集合推送视图?(Flash Builder 4.6,Flex),apache-flex,list,pushviewcontroller,flash-builder,arraycollection,Apache Flex,List,Pushviewcontroller,Flash Builder,Arraycollection,我有一个应用程序,它有一个计算器名称的数组集合。选择后,我想推动该项目的计算器的实际视图 这是我的代码,有人能帮我写一个函数,让我这样做吗 <?xml version="1.0" encoding="utf-8"?> <s:View xmlns:fx="http://ns.adobe.com/mxml/2009" title="iCalculate" xmlns:s="library://ns.adobe.com/flex/spark" xmlns:mx="libra

我有一个应用程序,它有一个计算器名称的数组集合。选择后,我想推动该项目的计算器的实际视图

这是我的代码,有人能帮我写一个函数,让我这样做吗

<?xml version="1.0" encoding="utf-8"?>
    <s:View xmlns:fx="http://ns.adobe.com/mxml/2009" 
title="iCalculate"
xmlns:s="library://ns.adobe.com/flex/spark"
xmlns:mx="library://ns.adobe.com/flex/mx"
creationComplete="creationCompleted(event)"
width="100%" height="100%">

       <s:layout>   
    <s:VerticalLayout paddingTop="10"/>
   </s:layout>
<fx:Script>
    <![CDATA[
        import com.Watts.collections.filter.Evaluator;
        import com.Watts.demo.Album;

        import mx.collections.ArrayCollection;
        import mx.events.CollectionEvent;
        import mx.events.FlexEvent;
        import mx.rpc.http.Operation;

        import spark.components.Image;
        import spark.components.ViewMenu;
        import spark.components.gridClasses.GridColumn;
        import spark.events.IndexChangeEvent;
        import spark.events.TextOperationEvent;

// Everything Below this line holds information specifically relating to Beta 2

// Below this line is the coding for the search bar or filter bar 
        private var _collection:ArrayCollection;
        private var _evaluator:Evaluator = new Evaluator();

        private function creationCompleted(event:FlexEvent):void
        {
            _collection = Album.collection;
            _collection.filterFunction = filterCollection;

            _evaluator.synonyms["four"] = new ArrayCollection(["4"]);

            grid.dataProvider = _collection;
        }

        private function filterChanged(event:Event):void
        {
            update();


        }

        private function update():void
        {
            _evaluator.prepare(filter.text);
            _collection.refresh();

            formula.text = (_evaluator.tree) ?                              _evaluator.tree.toString() : "";

        }

        private function filterCollection(data:Object):Boolean
        {
            var labels:ArrayCollection = new ArrayCollection();
            for (var i:int; i < grid.columns.length; i++)
            {
                labels.addItem((grid.columns.getItemAt(i) as GridColumn).itemToLabel(data));
            }   
            return _evaluator.evaluate(labels);
        }

    ]]>
</fx:Script>


    <s:VGroup left="5" right="-9" top="5" bottom="5" width="100%" height="100%" textAlign="center">
    <s:TextInput id="filter" width="100%" change="filterChanged(event)"/>
    <s:DataGrid id="grid" width="100%" height="100%" textAlign="left">
    </s:DataGrid>
    <s:Label id="formula" />
    </s:VGroup>
    <s:Label id="lblWattsMessage" click="navigator.pushView(views.CompanyDetail)" color="#1021C7"
         fontFamily="_typewriter" fontSize="12" text="Powered by WATTS Professionals"
         textAlign="center" verticalAlign="middle"/>



</s:View>

以下是我用来解决此问题的代码。在flex应用程序中,有一个navigator.pushView组件可供使用。我遇到的问题是,我没有为每个计算器分配视图ID。这必须在ArrayCollection容器中完成


navigator.pushview(ViewID)

您尝试过什么;这种方法有什么问题?我们不是来为您编写代码的;而是为了帮助您解决编写代码时遇到的问题。我尝试了一个数组列表,其中包含视图中的flex对象列表。在我无法理解如何解释对象的搜索过滤器后,我使用了这个方法。现在,我无法再次执行推送视图。无论如何,我不是要求别人写我的代码。我只是请某人给我一个建议,为我指明正确的方向。