0

基本的に私が欲しいのは、データ グリッドから値をフィルター処理することです。これを成功させた例をいくつか見てきました。これらのように

http://dalvinder.serveblog.net/2011/06/25/flex-spark-datagrid-filtering/ ?

http://blog.bobklaas.com/?p=126 ?

問題は、これらの例のすべてがデータ グリッドのデータ プロバイダーとして事前定義された arraycollection を使用しているのに対し、callresponder の結果をデータ プロバイダーとして使用していることです。現在、私はphpサービスを使用してデータベースからデータを取得し、データグリッドにデータを入力しているため、コードは次のようになります

    <mx:DataGrid x="34.3" y="99.65" id="dataGrid"   creationComplete="dataGrid_creationCompleteHandler(event)" dataProvider="{getAllStudentsResult2.lastResult}"  width="711" headerHeight="25" change="dataGrid_changeHandler(event)" styleName="table" height="367"
                     alternatingItemColors="[#e0e0e0, #cacaca]"
                     horizontalScrollPolicy="auto">

callresponder の結果から値をフィルター処理できないようですので、このような resultevent ハンドラーを使用して callresponder の結果を別の arraycollection に転送しようとしました

[Bindable]private var searchArray:ArrayCollection = new ArrayCollection();//variable declaration


protected function getAllStudents2Result_resultHandler(event:ResultEvent):void
        {
            searchArray = event.result as ArrayCollection;  
        }

そして、データグリッドプロバイダーをこれに変更しました

dataProvider="{searchArray}"

次に、blog.bobklaas.com/?p=126 のこのコードを使用して、データグリッドをフィルタリングしました

            public function filterResults():void
        {

            var filterText:String = StringUtil.trim(keyword.text.toLowerCase()); //Trimmed text String to filter by
            var columnArray:Array = ['ID','FirstName','Lastname', 'Location', 'Level']; //Datagrid column names to filter on
            var gridDataProvider:ArrayCollection = searchArray; //Name of datagrid's dataprovider. In this case e.g. databases
            var dataGridName:String = 'dataGrid'; //Name of the datagrid you are filtering by

            //Do not edit code past this point
            var filteredData:Array = [];
            var added:Boolean=false;
            var i:int;
            var j:int;

            // Loop Through Grid
            for(i=0; i < gridDataProvider.length; i++){    
                added = false;
        //  Alert.show(gridDataProvider.getItemAt(i).toString());
                //Loop through grid column
                for(j=0; j<columnArray.length; j++){  


                    if(gridDataProvider[i][columnArray[j]]!=null){
                        //Grab datagrid cell contents, trim it, and convert to lowercase for comparison.
                        var filterString:String = gridDataProvider[i][columnArray[j]].toString().toLowerCase();

                        //Compare the datagrid string(filterString) to the user typed string(filterText).  
                        if(!added){      
                            //If the datagrid string matches the users string, put it into the array.

                            if(filterString.indexOf(filterText) != -1){

                                filteredData.push(gridDataProvider[i]);
                                added = true;
                            } 
                        }else{
                            //Do nothing, break out.
                            break;
                        }
                    }    
                }
            }

            //Set datagrid dataprovider
            if(filterText.length == 0){
                this[dataGridName].dataProvider = gridDataProvider; //Display the original unfiltered data
            }else{
                this[dataGridName].dataProvider = filteredData; //Pusht he filtered data into the datagrid
            }
        }

アプリケーションを実行した後、何も起こりません。searchArray から値をフィルタリングすることはまだできません。

誰かがより良い解決策を提案できますか、それとも私は何か間違っていますか???

4

1 に答える 1