用Angular动态添加、删除输入框并计算总值

这个功能本身并不复杂,但还是要注意,每个ng-model的对象必须是不同的,这样才能把它们分隔开。

下面是完整代码:

JS:

 angular.module("myApp",[])
 .controller("inputController",function($scope){
        $scope.items=[];    //初始化数组,以便为每一个ng-model分配一个对象
        var i=0;
        $scope.getResult=function(){      //计算输入框的总值
            var result=0;
            angular.forEach($scope.items,function(item,key){
                result+=parseInt($scope.items[key]);
            })
            $scope.result=result;
        }

        $scope.Fn= {
            add: function () {         //每次添加都要给items数组的长度加一
                $scope.items[i] = 0;
                i++;
            },
            del: function (key) {      //每次删除一个输入框都后要让i自减,否则重新添加时会出bug
                console.log(key);
                $scope.items.splice(key, 1);
                i--;
                $scope.getResult();    //每次删除时得重新计算总值
            }
        }

    })

HTML:

<body ng-controller="inputController">
    <div ng-repeat="(key,item) in items track by $index">   <!-- 借助track by $index进行循环-->
         <input ng-model="items[key]"/><button ng-click="Fn.del(key)">删除</button>
    </div>

{{result}}
<button ng-click="Fn.add()">Add</button>
    <button ng-click="getResult()">Result</button>
</body>

应该没有什么bug。但如果有什么更漂亮的做法,恳请大神分享一下,因为我知道这样写并不是很优雅。

转载于:https://my.oschina.net/u/2342955/blog/469551

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值