虚位以待(AD)
虚位以待(AD)
首页 > 网页特效 > Jquery > Angular动态添加、删除输入框并计算值实例代码

Angular动态添加、删除输入框并计算值实例代码
类别:Jquery   作者:码皇   来源:互联网   点击:

这篇文章主要介绍了Angular动态添加、删除输入框并计算值实例代码的相关资料,需要的朋友可以参考下

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。但如果有什么更漂亮的做法,恳请大神分享一下,因为我知道这样写并不是很优雅。

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

相关热词搜索: Angular动态添加、删除输入框并计算值 Ang