How to make an ng-click event conditional?

后端 未结 6 455
既然无缘
既然无缘 2020-12-07 15:03

I have this code inside ng-repeat:

Do something

H

相关标签:
6条回答
  • 2020-12-07 15:47

    It is not good to manipulate with DOM (including checking of attributes) in any place except directives. You can add into scope some value indicating if link should be disabled.

    But other problem is that ngDisabled does not work on anything except form controls, so you can't use it with <a>, but you can use it with <button> and style it as link.

    Another way is to use lazy evaluation of expressions like isDisabled || action() so action wouold not be called if isDisabled is true.

    Here goes both solutions: http://plnkr.co/edit/5d5R5KfD4PCE8vS3OSSx?p=preview

    0 讨论(0)
  • 2020-12-07 15:49

    We can add ng-click event conditionally without using disabled class.

    HTML:

    <div ng-repeat="object in objects">
    <span ng-click="!object.status && disableIt(object)">{{object.value}}</span>
    </div>
    
    0 讨论(0)
  • 2020-12-07 15:53

    I had this issue also and I simply found out that if you simply remove the "#" the issue goes off. Like this :

    <a href="" class="disabled" ng-click="doSomething(object)">Do something</a>
    
    0 讨论(0)
  • 2020-12-07 15:55

    I use the && expression which works perfectly for me.

    For example,

    <button ng-model="vm.slideOneValid" ng-disabled="!vm.slideOneValid" ng-click="vm.slideOneValid && vm.nextSlide()" class="btn btn-light-green btn-medium pull-right">Next</button>
    

    If vm.slideOneValid is false, the second part of the expression is not fired. I know this is putting logic into the DOM, but it's a quick a dirty way to get ng-disabled and ng-click to place nice.

    Just remember to add ng-model to the element to make ng-disabled work.

    0 讨论(0)
  • 2020-12-07 15:56

    You could try to use ng-class.
    Here is my simple example:
    http://plnkr.co/edit/wS3QkQ5dvHNdc6Lb8ZSF?p=preview

    <div ng-repeat="object in objects">
      <span ng-class="{'disabled': object.status}" ng-click="disableIt(object)">
        {{object.value}}
      </span>
    </div>
    

    The status is a custom attribute of object, you could name it whatever you want.
    The disabled in ng-class is a CSS class name, the object.status should be true or false

    You could change every object's status in function disableIt.
    In your Controller, you could do this:

    $scope.disableIt = function(obj) {
      obj.status = !obj.status
    }
    
    0 讨论(0)
  • 2020-12-07 16:04

    Basically ng-click first checks the isDisabled and based on its value it will decide whether the function should be called or not.

    <span ng-click="(isDisabled) || clicked()">Do something</span>
    

    OR read it as

    <span ng-click="(if this value is true function clicked won't be called. and if it's false the clicked will be called) || clicked()">Do something</span>
    
    0 讨论(0)
提交回复
热议问题