ng-repeat 中动态绑定ng-click 点击事件处理函数&动态改变ng-class

本文仅仅是个人学习笔记,如有错误的地方请大家指正,谢谢!

在ng-repeat中动态的根据datas数据为各个条目中的ng-click绑定不同的处理函数:
可以通过为处理函数传入不同的参数来实现。
注意:参数不能用{{}}包裹。

//html
<ul ng-controller="InputCtrl" style="width: 90%">
                <li ng-repeat="data in datas">
                    <div ng-class="{true:'customInputFilled',false:'customInputNotFilled'}[data.isFilled]"  
                    ng-click="do(data.functionId)">
                        <p style="float: left">{{data.info}}</p>
                        <p style="float: right;">{{data.value!=null?data.value:"未填写"}}</p>
                    </div>
                </li>
            </ul>
//controller
      $scope.do = function(id){

        switch(id){
          case 0:
                $scope.showSetHeightPopup();
                break;
          case 1:
                $scope.openDatePicker();
                break;
          default :
            console.log(id);
                break;
        }
      };

可以通过三种方法动态改变ng-class:

  1. ng-class= "{{value}}"//value为ng-controller中的变量,通过改变变量的值来达到改变ng-class
  2. ` ng-class=”{true:’customInputFilled’,false:’customInputNotFilled’}[data.isFilled]”//通过改变data.isFilled这个值为true或false来明确的指出使用两种class中的哪一种
  3. ng-class = “{‘customInputFilled’:a,’customInputNotFilled’:b}” //a,b为controller中的变量,两者中为true的则class为他所对应的值
    `
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值