IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Flex Discussion :

Bug DataGrid avec ItemRenderer


Sujet :

Flex

  1. #1
    Membre averti
    Inscrit en
    Avril 2002
    Messages
    53
    Détails du profil
    Informations forums :
    Inscription : Avril 2002
    Messages : 53
    Par défaut Bug DataGrid avec ItemRenderer
    Bonjour,

    j'ai une DataGrid dont le dataProvider est une collection d'objets.
    Cette DataGrid possède une colonne affichant une checkbox (via un itemRenderer) pour chaque éléments.
    Si je coche des checkbox et que je mets ensuite à jour ma collection d'objets, les checkbox cochées ne restent pas à leur place

    Pour illustrer cela voici un code très simple qui reproduit le bug :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
     
    <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" 
        creationComplete="onCreationComplete()">
     
    	<mx:Script>
    		<![CDATA[
     
    			import mx.collections.ArrayCollection;
     
    			[Bindable]
    			public var collection:ArrayCollection
     
    			public function onCreationComplete():void {
    				collection = new ArrayCollection();
    				collection.addItem(new Object().name = "AAA");
    				collection.addItem(new Object().name = "BBB");
    				collection.addItem(new Object().name = "CCC");	
    			}
     
    			public function updateProvider():void {
    				collection = new ArrayCollection();
    				collection.addItem(new Object().name = "DDD");
    				collection.addItem(new Object().name = "EEE");
    				collection.addItem(new Object().name = "FFF");
    			}
     
    		]]>
    	</mx:Script> 
     
    	<mx:DataGrid dataProvider="{collection}">
    		<mx:columns>
    			<mx:DataGridColumn>
                	            <mx:itemRenderer>
    			        <mx:Component>
    				     <mx:CheckBox label="{data.name}"/>
    				</mx:Component>
    			    </mx:itemRenderer>
    			</mx:DataGridColumn>    
    		</mx:columns>
    	</mx:DataGrid>
     
    	<mx:Button label="Update provider" click="updateProvider()" />
     
    </mx:Application>
    Si je démarre cette application je me retrouve avec 3 checkboxes dans ma datagrid :

    [ ] AAA
    [ ] BBB
    [ ] CCC

    Je coche par exemple ensuite la 1ere et la 2e checkbox:
    [x] AAA
    [x] BBB
    [ ] CCC

    J'appuie ensuite sur le bouton "Update Provider" et je me retrouve avec :
    [ ] DDD
    [x] EEE
    [x] FFF

    alors que je devrais plutôt me retrouver avec :
    [x] DDD
    [x] EEE
    [ ] FFF

    Quelqu'un aurait une explication à cette étrange phénomène et une manière de le résoudre?

    Note : Ca bug également si j'utilise des RadioButtons.

    Merci d'avance

  2. #2
    Invité de passage
    Inscrit en
    Février 2009
    Messages
    1
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 1
    Par défaut CheckBox dans un DataGrid
    Tu as tout simplement oublié de définir la propriété selected du checkbox.

    Voici ton code corrigé :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
     
    <mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" 
        creationComplete="onCreationComplete()">
     
    	<mx:Script>
    		<![CDATA[
     
    			import mx.collections.ArrayCollection;
     
    			[Bindable]
    			public var collection:ArrayCollection
     
    			public function onCreationComplete():void {
    				collection = new ArrayCollection();
     
    				var obj:Object = new Object();
    				obj.name = "AAA";
    				obj.checked = false;
    				collection.addItem(obj);					 
     
    				var obj:Object = new Object();
    				obj.name = "BBB";
    				obj.checked = false;
    				collection.addItem(obj);					 
     
    				var obj:Object = new Object();
    				obj.name = "CCC";
    				obj.checked = false;
    				collection.addItem(obj);					
     
    			}
     
    			public function updateProvider():void {
    				collection = new ArrayCollection();
     
    				var obj:Object = new Object();
    				obj.name = "DDD";
    				obj.checked = false;
    				collection.addItem(obj);					 
     
    				var obj:Object = new Object();
    				obj.name = "EEE";
    				obj.checked = false;
    				collection.addItem(obj);					 
     
    				var obj:Object = new Object();
    				obj.name = "FFF";
    				obj.checked = false;
    				collection.addItem(obj);		
     
    			}
     
    		]]>
    	</mx:Script> 
     
    	<mx:DataGrid dataProvider="{collection}">
    		<mx:columns>
    			<mx:DataGridColumn>
                	         <mx:itemRenderer>
    			        <mx:Component>			        
    				    	<mx:CheckBox label="{data.name}" selected="{data.checked}" />
    					</mx:Component>
    			    </mx:itemRenderer>
    			</mx:DataGridColumn>    
    		</mx:columns>
    	</mx:DataGrid>
     
    	<mx:Button label="Update provider" click="updateProvider()" />
     
    </mx:Application>

  3. #3
    Membre averti
    Inscrit en
    Avril 2002
    Messages
    53
    Détails du profil
    Informations forums :
    Inscription : Avril 2002
    Messages : 53
    Par défaut
    L'ajout du booléen checked de façon dynamique dans mon exemple simple fonctionne bien mais le problème ç'est que dans mon application les objets de ma collection ne possèdent pas de booléen permettant de dire si la checkbox doit être cochée ou non (Ils ne sont quand même pas censés s'avoir qu'il vont être affiché dans une datagrid possédant des checkbox, cette propriété booléenne n'aurait aucun sens en dehors de ce contexte particulier).

  4. #4
    Membre Expert
    Avatar de Jim_Nastiq
    Homme Profil pro
    Architecte, Expert Flex
    Inscrit en
    Avril 2006
    Messages
    2 335
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Architecte, Expert Flex
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2006
    Messages : 2 335
    Par défaut
    le problème doit se situer au niveau du sort en fait quand tu update un le dataprovider d'un datagrid il n'ont pas d'ordre définit , il y'a surement qq chose à ce niveau la. je te conseille de passer en mode débug pour suivre le comportement de plus près

    Pensez vraiment à effectuer une recherche avant de poster, ici et sur un moteur de recherche! c'est la moindre des choses
    Pensez au tag

    Mon Blog sur la techno Flex
    Ma page sur Developpez.com

    Jim_Nastiq

  5. #5
    Membre averti
    Inscrit en
    Avril 2002
    Messages
    53
    Détails du profil
    Informations forums :
    Inscription : Avril 2002
    Messages : 53
    Par défaut
    Bon finalement j'ai trouvé.
    C'est pas vraiment un bug mais une implémentation assez bizarre des itemRenderers. Les instances d'itemRenderers sont recyclées pouvant donner lieu à des comportements étranges.

    Plus de détails ici :

    http://devharbor.blogspot.com/2008/0...ng-issues.html.
    http://www.dgrigg.com/post.cfm/10/20...heckBox-Sample

    La seule solution est donc bien de créer une propriété booléenne 'factice' dans la classe représentant nos objets (ou créer des objets d'un nouveau type encapsulant nos objets de base + ce booléen) pour stocker l'état de la checkbox en l'utilisant de cette manière:

    <mx:CheckBox click="data.checked=!data.checked" selected="{data.checked}"/>

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. datagrid editable Itemrenderer avec checkbox
    Par Cdic83 dans le forum MXML
    Réponses: 3
    Dernier message: 18/05/2009, 22h00
  2. [CSS] Bug IE avec height ne marche pas avec les %
    Par El Riiico dans le forum Mise en page CSS
    Réponses: 3
    Dernier message: 23/06/2005, 17h11
  3. [C#] Colonne de trop dans DataGrid avec SQLCE
    Par Roach- dans le forum Windows Forms
    Réponses: 2
    Dernier message: 07/04/2005, 20h01
  4. Réponses: 2
    Dernier message: 01/07/2004, 11h05
  5. Bug Xerces2_1_0 avec C++ et Linux ??
    Par _marie_ dans le forum XML
    Réponses: 2
    Dernier message: 24/09/2003, 07h49

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo