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对象列表。在我无法理解如何解释对象的搜索过滤器后,我使用了这个方法。现在,我无法再次执行推送视图。无论如何,我不是要求别人写我的代码。我只是请某人给我一个建议,为我指明正确的方向。