Angular动态添加、删除输入框并计算值实例代码
- 作者: 一梦一轮回丶
- 来源: 51数据库
- 2021-08-28
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中响应式表单的三种更新值方法详析
7
Angularjs实现下拉框联动的示例代码
7
详解AngularJS跨页面传值(ui-router)
2
详解AngularJS1.x学习directive 中‘& ’‘=’ ‘@’符号的区别使用
3
angular2路由切换改变页面title的示例代码
4
Angular2 组件间通过@Input @Output通讯示例
5
Angularjs中ng-repeat的简单实例
3
AngularJS 中ui-view传参的实例详解
4
浅谈Angular路由守卫
4
详解基于Angular4+ server render(服务端渲染)开发教程
4