web-dev-qa-db-fra.com

Basculer classe avec ng-clic sur plusieurs éléments

Comment puis-je basculer des classes sur plusieurs éléments individuellement avec ng-click?

Dans cette question https://stackoverflow.com/a/22072110/2169327 le basculement des classes en un clic a été effectué comme suit:

CSS:

.red {
    color: red;
}

JS:

$scope.toggle = false;

HTML:

<button id="btn" ng-click="toggle = !toggle" ng-class="{'red' : toggle}">Change Class</button>

Mais que se passe-t-il si j'ai plusieurs boutons que chacun devrait basculer dans sa propre classe avec ng-click? 

Si je l'installe de cette façon:

HTML:

<button id="btn" ng-click="toggle = !toggle" ng-class="{'red' : toggle}">Change Class</button>
<button id="btn2" ng-click="toggle = !toggle" ng-class="{'red' : toggle}">Change Class</button>

Les deux boutons sont basculés si j'appuie sur l'un d'eux.

Je sais qu'une solution de contournement consiste à définir un propre événement ng-click pour chaque bouton (f.ex toggle1 pour button1, toggle2 pour button2).

34
bjornasm

J'ai fait une directive simple pour les tests:

module.directive('toggleClass', function() {
    return {
        restrict: 'A',
        link: function(scope, element, attrs) {
            element.bind('click', function() {
                element.toggleClass(attrs.toggleClass);
            });
        }
    };
});

afin que vous puissiez faire n'importe quelle classe de bascule d'élément dont vous avez besoin

<button id="btn" toggle-class="active">Change Class</button>
<div toggle-class="whatever"></div>
64
Zombi

Selon vos besoins, vous pourrez peut-être utiliser un ng-repeat avec un tableau représentant les bascules. Par exemple:

Ta vue:

<div ng-repeat="toggle in toggles">
    <button id="btn" ng-click="toggle.state = !toggle.state" ng-class="{'red' : toggle.state}">Change Class</button>
</div>

Dans votre contrôleur:

$scope.toggles = [{ state: true }, { state: false }, { state: true }];

De cette façon, vous pouvez développer votre jeu de boutons en mettant simplement à jour le tableau ou les objets de tableau internes (si vous avez besoin de plus de complexité).

18
Matt Way

contrôleur intérieur 

 $scope.stateToggle=false;
$scope.togglelasses=function(){
     $scope.stateToggle= !$scope.stateToggle;
}

en vue utiliser ng-class

 <button ng-click="togglelasses()" ng-class="stateToggle? 'active ': ' '">

ajouter ng-class dans chaque élément où vous voulez activer la classe 

0
rishabh