明霞山资源网 Design By www.htccd.com
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。但如果有什么更漂亮的做法,恳请大神分享一下,因为我知道这样写并不是很优雅。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
明霞山资源网 Design By www.htccd.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
明霞山资源网 Design By www.htccd.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。