J'ai une grille de données, peuplée comme indiqué ci-dessous. Lorsque l'utilisateur clique sur un en-tête de colonne, je voudrais trier les lignes en utilisant un tri lexicographique dans lequel la colonne sélectionnée est utilisée en premier, puis les colonnes restantes sont utilisées de gauche à droite pour rompre les liens. Comment puis-je coder ceci?comment trier un DataGrid flexible selon plusieurs colonnes?
(! Je une réponse que je vais poster ci-dessous, mais il a un problème - je serai très heureux si quelqu'un peut fournir un meilleur)
est ici la mise en page:
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml"
layout="absolute" creationComplete="onCreationComplete()">
<mx:Script source="GridCode.as" />
<mx:DataGrid id="theGrid" x="61" y="55" width="466" height="317">
<mx:columns>
<mx:DataGridColumn dataField="A"/>
<mx:DataGridColumn dataField="B"/>
<mx:DataGridColumn dataField="C"/>
</mx:columns>
</mx:DataGrid>
</mx:Application>
Et voici le code de support:
import mx.collections.ArrayCollection;
import mx.collections.Sort;
import mx.collections.SortField;
import mx.controls.dataGridClasses.DataGridColumn;
import mx.events.DataGridEvent;
public function onCreationComplete():void
{
var ar:ArrayCollection = new ArrayCollection();
var ob:Object;
for(var i:int=0; i<20; i++)
{
ob = new Object();
ob["A"] = i;
ob["B"] = i%3;
ob["C"] = i%5;
ar.addItem(ob);
}
this.theGrid.dataProvider = ar;
}