Make a dynamic function on ng-click

后端 未结 3 1470
臣服心动
臣服心动 2021-01-02 04:39

I have button like this


相关标签:
3条回答
  • 2021-01-02 05:01

    Use of bracket notation:

    <button ng-click="this[method](param)">{{ title }}</button>
    

    this points to current scope object so with this[method] you can access method via variable name.

    0 讨论(0)
  • 2021-01-02 05:05

    This syntax seems working well

    <button ng-click="this[method(param)]">{{ title }}</button>
    

    starting from the suggestion of user dfsq and as the suggestion wasn't working with angularjs 1.6.4, I put the closing braket after the param value.

    0 讨论(0)
  • 2021-01-02 05:06

    This didn't work for me.. and..

    I didn't want to deal with having html code in my angular app, or directives, or the use of eval. so I just wrapped my existing functions in a function:

    $scope.get_results = function(){
    
        return {
                message: "A message", 
                choice1: {message:"choice 1 message", f: function(){$scope.alreadyDefinedFunction1()}},
                choice2: {message:"choice 2 message", f: function(){$scope.alreadyDefinedFunction2()}},
            };
    }
    

    in a different function:

    $scope.results2 = $scope.get_results();
    

    Snippet of use in html:

    <ul class="dropdown-menu scroll-div">
      <li><a ng-click="results2.choice1.f()">{{results_2_menu.choice1.message}}</a></li>
      <li><a ng-click="results2.choice2.f()">{{results_2_menu.choice2.message}}</a></li>
    </ul>
    

    Was based on this js fiddle: http://jsfiddle.net/cdaringe/FNky4/1/

    0 讨论(0)
提交回复
热议问题