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

Ext JS / Sencha Discussion :

Checkbox et Datastore


Sujet :

Ext JS / Sencha

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 11
    Par défaut Checkbox et Datastore
    Bonjour,

    Je m'initie petit à petit à Extjs en travaillant avec la version 4.
    Je cherche à créer, dans un formulaire, des checkbox alimentées par un DataStore (qui récupère les valeurs dans ma BDD).

    J'ai essayé de faire de la même manière que les combobox dynamiques mais, ça ne marche pas..

    Quelqu'un aurait-il déjà fait cela ou aurait une piste pour m'aider ?
    Un grand merci par avance,

    Cdlmt

  2. #2
    Membre émérite Avatar de kenny.kev
    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    646
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2007
    Messages : 646
    Par défaut
    Bonjour à toi,

    Personnellement je ne vois pas comment tu pourrais faire sens utiliser Extdirect.

    Pour le dynamisme il faut que tu crées un objet Extjs avec Ext.define ()
    C'est un objet que tu peux personnaliser.
    Extdirect va te permettre d'appeler tes données avec lequel tu pourras construire tes checkbox.

    J'ai l'impression qu'au final c'est un combobox avec sélection multiple...

    Bon courage

  3. #3
    Expert confirmé
    Avatar de sekaijin
    Homme Profil pro
    Urbaniste
    Inscrit en
    Juillet 2004
    Messages
    4 205
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Urbaniste
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2004
    Messages : 4 205
    Par défaut
    Pourquoi Ext.direct ????

    ExtJS fonctionnait bien avant ça.

    A+JYT

  4. #4
    Membre émérite Avatar de kenny.kev
    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    646
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Janvier 2007
    Messages : 646
    Par défaut
    Citation Envoyé par sekaijin Voir le message
    Pourquoi Ext.direct ????

    ExtJS fonctionnait bien avant ça.

    A+JYT
    Oui pardon extdirect n'est pas utile. J'ai eu un gros trou de mémoire...

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Juin 2008
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2008
    Messages : 11
    Par défaut
    Bonjour à tous,

    Bon alors en fait, avec de l'aide, j'ai trouvé. Contrairement à ce que je pensais, ça n'était pas si évident que ça finalement...

    En fait, il faut d'abord créer un objet checkboxgroup vide, puis le remplir lors du load du store.

    Pour accéder à mes objets sans être gênée par la portée des variables, dans un fichier js à part (là ou je déclare tous les require), je déclare d'abord une variable d'appel vide (appel), puis j'instancie un nouvel objet à partir de ma classe (mes_checkboxs).

    Je peux accéder ainsi à mes objets facilement en tapant :
    appel.mon_objet.nom_variable...

    Fichier main.js
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    var appel = {};
     
    Ext.onReady(function() {
    	appel.mon_objet = new mes_checkboxs(); //instanciation d'un objet
    });
    Fichier du form
    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
     
    //L'objet principal
    var mes_checkboxs = function (){
     
     
    //Creation du store
    this.store = new Ext.data.Store({
          storeId:'store1',
          autoload:true,
          fields:['champ1', 'champ2','champ3'],
          proxy: {
                type: 'ajax',
                url:'monurl.php',
                reader: {
    	            type: 'json',
    	            root: 'data'
                }
          }
    }).load(function(records,operation,success){
              var test = appel.mon_objet.store.getAt(0); //recupere l'enregistrement à l'index spécifié
              var test2 = appel.mon_objet.store; //pour appeler le store
              var nbre = test2.getCount(); //nombre de valeurs récupérées
              registre.checkbox.form.removeAll(); //efface tous les champs du form
     
              for(var i = 0; i < nbre;i++){
                   test = appel.mon_objet.store.getAt(i);
                   appel.mon_objet.checkboxgroup = null; //vide l'objet checkboxgroup au cas ou non vide avant
                   var lacheckbox ={ //creation de la structure de l'objet
                        xtype:'checkbox',  
                        boxLabel : test.get('champ1'),
                        fieldLabel: '',
                        labelWidth:  150,
                        checked: true,
                        name: 'toto'			
                   };
                   appel.mon_objet.form.add(lacheckbox); //ajoute les objets un par un (pas de tableau) à mon form
            }
    });
     
    	this.checkboxgroup = {}; //creer l'objet vide pour le declarer au constructeur de la classe
     
    //objet formulaire de la fenetre
    	this.form = new Ext.form.Panel({
    		layout:'anchor',			 			
    		bodyPadding:'10 10 10 10',	//padding
    		url: 'autre_url.php',
    		defaults:{
    			anchor:'75%',
    			labelAlign: 'right',
    			labelWidth:  100
    		},
    		id:'form_checkbox',		
    		items:[{
     
    		},
    			this.checkboxgroup	
    		]
    	});
     
    };
    Je ne suis pas spécialiste en extjs. On m'a beaucoup aidé pour ce bout de code et comme j'ai pas mal galéré sans trouver grand chose sur le net, j'ai choisi de le poster si ça peut en aider d'autres, mais je ne suis pas sure d'arriver à faire du 'SAV' dessus.

    Merci pour cette communauté

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

Discussions similaires

  1. [JSP]checkbox
    Par orisis dans le forum Servlets/JSP
    Réponses: 6
    Dernier message: 16/04/2013, 13h53
  2. [VB.NET] Insérer une colonne de CheckBox dans un DataGrid
    Par Manue.35 dans le forum Windows Forms
    Réponses: 2
    Dernier message: 22/05/2003, 11h44
  3. Checkbox
    Par rgarnier dans le forum XMLRAD
    Réponses: 11
    Dernier message: 06/03/2003, 10h48
  4. Couleur d'un CheckBox
    Par benj63 dans le forum C++Builder
    Réponses: 4
    Dernier message: 15/07/2002, 14h48
  5. CheckBox en Read Only
    Par MrJéjé dans le forum C++Builder
    Réponses: 7
    Dernier message: 23/06/2002, 15h00

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