Comment mettre à Jour Élevée titre du Bouton sur Pressée, en Particulier, l'indice de la liste.constructeur

0

La question

Voici mon code.

bool isAddedToCart = false;
return ListView.builder(
........
 ElevatedButton (
                        child: isAddedToCart? Text('Added to cart') : Text('Add to cart'),
                         style: ElevatedButton.styleFrom(
                           primary: Constants.primaryColor,
                           onPrimary: Constants.appColor
                         ),
                         onPressed: () async{
                           setState(() {
                             isAddedToCart = !isAddedToCart;
                           });
                           
                         },
                      
                       ),

Le problème est que si je clique sur que des taux élevés de Bouton, le texte de ce bouton a changer sur cet index n'. Mais il est en train de changer dans tous les index qui sont dans la liste.générateur de rapports.

Peut-on avoir une solution pour cela qu'un seul bouton sur une sélection d'index de a à mettre à jour avec le changement de nom.

flutter
2021-11-24 05:13:26
2

La meilleure réponse

2

Vous avez besoin de garder le drapeau isAddedToCart pour chaque indice. Vous pouvez la réaliser à l'aide d'un Map. Quelque chose comme ceci:

// class variable scope.
Map<int, bool> isAddedToCartMap = {};

ensuite l'utiliser dans votre widget:

ElevatedButton (
    // if isAddedToCartMap[index] not found, use false as default value.
    child: isAddedToCartMap[index]??false ? Text('Added to cart') : Text('Add to cart'),
     style: ElevatedButton.styleFrom(
       primary: Constants.primaryColor,
       onPrimary: Constants.appColor
     ),
     onPressed: () async{
       setState(() {
         isAddedToCartMap[index] = !isAddedToCartMap[index]??false;
       });
       
     },
  
   ),
2021-11-24 05:24:43

sa fonctionne très bien, j'ai un dout.. Comment mettre à jour le même bouton 'Ajouter au panier' de nouveau. merci pour la réponse @ישו אוהב אותך
H ă ɤ í
1

Tous les articles ont été dépend isAddedToCart mais Vous avez besoin de stocker l'élément sélectionné à l'aide d'indexation distincts

List<int> _selected_item = List();

 ElevatedButton(
              child: _selected_item.contains(index)
                  ? Text('Added to cart')
                  : Text('Add to cart'),
              style: ElevatedButton.styleFrom(),
              onPressed: () async {
                setState(() {
                  // remove or add index to _selected_item
                  if (_selected_item.contains(index))
                    _selected_item.remove(index);
                  else
                    _selected_item.add(index);
                  print(index);
                });
              },
            )

le code source complet

ListView.builder(
          itemCount: 5,
          itemBuilder: (context, index) {
            return ElevatedButton(
              child: _selected_item.contains(index)
                  ? Text('Added to cart')
                  : Text('Add to cart'),
              style: ElevatedButton.styleFrom(),
              onPressed: () async {
                setState(() {
                  // remove or add index to _selected_item
                  if (_selected_item.contains(index))
                    _selected_item.remove(index);
                  else
                    _selected_item.add(index);
                  print(index);
                });
              },
            );
          })
2021-11-24 06:01:37

@GH vous pouvez essayer ce que j'espère, il va travailler pour vous
Jahidul Islam

c'était super. merci.
H ă ɤ í

il était arriver à défaut lorsque c'est le rechargement. Peut-on faire à l'aide de modèle, si oui, comment?
H ă ɤ í

vous devez suivre ce lien stackoverflow.com/questions/57380673/...
Jahidul Islam

Dans d'autres langues

Cette page est dans d'autres langues

Русский
..................................................................................................................
Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Türk
..................................................................................................................
Česk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................