热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

angularjscheckbox全选单选批量删除

相信许多同学在项目实际开发中都能面对到批量选择,然后进行批量操作的问题,我百度过许多angularjs的批量操作的方法,但是都不够简洁明白

相信许多同学在项目实际开发中都能面对到批量选择,然后进行批量操作的问题,我百度过许多angularjs的批量操作的方法,但是都不够简洁明白,我个人整合一个比较清晰的思路给大家,这也是本小白的第一个csdn博客,希望能对需要的人有所帮助。

先说一下批量操作的思路,就是把你需要操作的所有信息的所有Id封装成一个json数组传递到后台。


首先先看一下html代码


编号姓名
{{item.id}}{{item.name}}

Selected : {{selected}}


解释一下html的结构,第一个全选checkbox绑定一个函数all($event,datas),这个函数的作用是点击它将所有的checkbox置为true或false然后将所有的id放进selected[]中。

循环中的checkbox中的函数updateSelection($event,item.id)作用是更新selected[]数组中的id,你如果选择或取消某条数据的话,相应的selected[]数组就会取消或者增加.


然后我们来看一下控制器


//checkbox全选单选$scope.selected = [] ;//定义一个数组 //全选方法,并将所有的id一并传入selected数组中$scope.all = function($event,data){var checkbox = $event.target ; var checked = checkbox.checked ; if(checked){$scope.x=true;for(var key in data){if($scope.selected.indexOf(data[key].id)>=0){//判断数组中是否重复存在continue;}else{$scope.selected.push(data[key].id);}}console.log($scope.selected);}else{$scope.x=false;$scope.selected=[];}};$scope.updateSelection = function($event,id){ //单选更新selectedvar checkbox = $event.target ; var checked = checkbox.checked ; if(checked){ $scope.selected.push(id);}else{ var idx = $scope.selected.indexOf(id) ; $scope.selected.splice(idx,1); } }//批量删除$scope.alldelete = function(){var url='/jsjxyxt/advice/alldelete.do';var datas={dataObject:$scope.selected,};$http.post(url,datas).success(function(data){if(data.msg=="0"){toaster.pop('error', '系统提示', '删除失败');}else{toaster.pop('success', '系统提示','批量删除成功');$timeout(function(){$scope.$apply(function(){$scope.datas = data.result;})})} })}




这两个方法的作用上边我都解释了,这里重点说一下我感到比较难理解的部分一个是 for循环循环json数组,这个我因为是小白不经常使用,所以查了好久才找到这个方法,

在一个就是

$scope.selected.indexOf(data[key].id)>=0

这个方法是判断数组中是否已经存在该id,用来防止重复存放的。

后面的请求后台就不说了吧,比较容易懂。希望能帮到需要的人。


推荐阅读
author-avatar
薛佩璇-_585
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有