欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Angular动态添加、删除输入框并计算值实例代码

程序员文章站 2022-07-05 21:18:47
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。但如果有什么更漂亮的做法,恳请大神分享一下,因为我知道这样写并不是很优雅。

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