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

VueJS Discussion :

Avoir une data v-model dynamique dans le cas de multiples tableaux


Sujet :

VueJS

  1. #1
    Membre à l'essai
    Femme Profil pro
    Ergonome
    Inscrit en
    Août 2014
    Messages
    52
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Ergonome

    Informations forums :
    Inscription : Août 2014
    Messages : 52
    Points : 24
    Points
    24
    Par défaut Avoir une data v-model dynamique dans le cas de multiples tableaux
    Hello !

    Voici mon problème : j'affiche plusieurs tableaux à la suite au moyen d'une boucle.
    Pour chacun des tableaux j'ai une checkbox qui permet de sélectionner touts les lignes du tableaux.
    Cette checkbox est relié avec un v-model="selectAll". Et on la retrouve dans l'instance de vue au niveau de data.

    Seulement voilà : chaque tableau a le meme v-model et est donc relié au même élément data donc cela ne fonctionne pas : lorsque je sélectionne tout du premier tableau, toutes les lignes sont bien sélectionnés mais également la checkbox qui concerne le select All du second tableau, et du troisieme etc.

    Le code html :
    Code html : 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
      <div id="app">
          <div>
            <div>
            {{ selectCheck }}
              <div v-for="(dimension, index) in listQuestions" :key="index" >
     
                <table class="table-questions" >
                    <thead>
                      <tr>
                        <th><input type="checkbox" @click="select(dimension)" v-model="selectAll" /></th>
                        <th>Sous-dimension</th>
                        <th>Item</th>
                      </tr>
                    </thead>
                    <tbody v-for="(question,i) in dimension.sousDimensions" >
                     <tr v-for="(item, p) in question.questions">
                        <!--some questions "barometre" disabled and checked by default-->
                        <td v-if="item.barometre"><input type="checkbox" checked disabled :id="'choice-' + item.id"/></td>
                        <td v-else ><input type="checkbox" v-model="selectCheck" :value="item.id" :id="'choice-' + item.id" /></td>
                        <td style="width: 60%">{{ question.name }}</td>
                        <td >{{item.item}}</td>
                      </tr>
                    </tbody>
                </table>
              </div>
            </div>
          </div>
      </div>

    La partie javascript:
    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
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    const columns = [
      {
        key: 'sousdimensions',
        scopedSlots: { customRender: 'name' },
      },
      {
        key: 'item',
        scopedSlots: { customRender: 'item' },
      },
    ];
     
    new Vue({
    el: "#app",
     
      methods: {
     
            select(value) {
          this.selectCheck = [];
          if (!this.selectAll) {
          for (var sousdim of value.sousDimensions)
          {
              for (var item of sousdim.questions)
              {
                this.selectCheck.push(item.id)
              }
            }
     
     
          }
        },
     
     
    },
    data: {
     columns,
          selectCheck: [],
          selectAll: false,
      listQuestions:
      [ 
      	{ 
        	"name": "Dimension 1", 
          "sousDimensions": 
          	[ 
            	{ 
              	"name": "Sous dimension 1.1", 
                "questions": 
                	[ 
                  	{ 
                    	"id": 1, 
                      "item": "Item 1.1.1", 
                      "barometre": false 
                    }, 
                    { 
                    	"id": 2, 
                      "item": "Item 1.1.2", 
                      "barometre": false 
                    }, 
                    { 
                    	"id": 3, 
                      "item": "Item 1.1.3", 
                      "barometre": true,  
                    } 
                  ] 
              }, 
              { 
              	"name": "Sous dimension 1.2", 
                "questions": 
                	[ 
                  	{ 
                    	"id": 4, 
                      "item": "Item 1.2.1", 
                      "barometre": false 
                    }, 
                    { 
                    	"id": 5, 
                      "item": "Item 1.2.2", 
                      "barometre": false 
                    }, 
                    { 
                    	"id": 6, 
                      "item": "Item 1.2.3", 
                      "barometre": true 
                    } 
                  ] 
              }, 
              { 
              	"name": "Sous dimension 1.3", 
                "questions": 
                	[ 
                  	{ 
                    	"id": 7, 
                      "item": "Item 1.3.1", 
                      "barometre": false
                    }, 
                    { 
                    "id": 8, 
                    "item": "Item 1.3.2", 
                    "barometre": false 
                    } 
                  ] 
              } 
            ] 
        }, 
        { 
        	"name": "Dimension 2", 
          	"sousDimensions": 
            [ 
            	{ 
              	"name": "Sous dimension 2.1", 
                "questions": 
                	[ 
                  	{ 
                    	"id": 9, 
                      "item": "Item 2.1.1", 
                      "barometre": false 
                    }, 
                    { 
                    	"id": 10, 
                      "item": "Item 2.1.2", 
                      "barometre": false 
                    }, 
                    { 
                    	"id": 11, 
                      "item": "Item 2.1.3", 
                      "barometre": false
                    }, 
                    { 
                    	"id": 12, 
                      "item": "Item 2.1.4", 
                      "barometre": true 
                    } 
                  ] 
              }, 
              { 
              	"name": "Sous dimension 2.2", 
                "questions": 
                	[ 
                  	{ 
                    	"id": 13, 
                      "item": "Item 2.2.1",
                      "barometre": false
                    }, 
                    {
                      "id": 14,
                      "item": "Item 2.2.2", 
                      "barometre": false
                    }, 
                    { 
                      "id": 15, 
                      "item": "Item 2.2.3", 
                      "barometre": false 
                    }, 
                    { 
                      "id": 16, 
                      "item": "Item 2.2.4", 
                      "barometre": true 
                    } 
                  ] 
              } 
            ] 
        }
      ],
     
     
      },
      },
     
     
      )
    Visible aussi ici pour voir le fonctionnement et mieux comprendre le problème : https://jsfiddle.net/chtouk/7xhn9q3w/20/

    Merci beaucoup pour votre aide

  2. #2
    Membre expérimenté
    Avatar de gwyohm
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2007
    Messages
    925
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Octobre 2007
    Messages : 925
    Points : 1 333
    Points
    1 333
    Par défaut
    hello,

    si tu utilises le même v-model pour chacun, en en cochant / décochant un, tu coches / décoches tous. c'est normal, ils ont le même modèle.
    Tu peux par exemple changer ton modèle selectAll pour que ce soit un objet qui contienne pour chaque dimension un booléen :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    selectAll: {
      'Dimension 1': false,
      'Dimension 2': false,
      // ...
    }
    et dans ton composant, tu peux faire
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    <input type="checkbox" @click="select(dimension)" v-model="selectAll[name]" />
    Mais je pense qu'avec cette méthode tu vas galérer encore après...
    Mon conseil ce serait plutôt de découper ton composant :
    1 composant qui gère les tableaux appelle n fois 1 composant qui gère un tableau

    en découpant, tu pourras facilement gérer le cas du selectAll car tu seras sur un scope data réduit, donc pas de questions à se poser sur les autres tableaux, chacun a son monde isolé
    tu pourras facilement ajouter des comportements comme quand je coche tous via selectAll, tous se cochent,
    j'en décoche 1, selectAll se décoche,
    je sélectionne tout manuellement, selectAll se coche tout seul...
    la bonne nouvelle, c'est que ce composant, c'est juste une simplification de celui que tu as déjà.

    Le composant englobant devra quant à lui faire la fusion des données des sous-composants.
    on ne dit pas "ça ne marche pas" on dit "je suis incapable de faire fonctionner correctement les outils mis à ma disposition"
    Pas de question technique par MP

Discussions similaires

  1. [XL-2013] Comment avoir une liste évolutive dans un menu déroulant ?
    Par bolide7 dans le forum Excel
    Réponses: 12
    Dernier message: 14/03/2014, 00h32
  2. Réponses: 6
    Dernier message: 15/04/2013, 15h20
  3. Réponses: 0
    Dernier message: 10/09/2009, 17h48
  4. comment avoir une valeur d'une form1 dans un autre form
    Par sabrina_beautyful dans le forum Windows Forms
    Réponses: 3
    Dernier message: 18/05/2009, 14h53
  5. Réponses: 12
    Dernier message: 25/04/2007, 11h36

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