热门标签 | 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,用来防止重复存放的。

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


推荐阅读
  • 使用nodejs爬取b站番剧数据,计算最佳追番推荐
    本文介绍了如何使用nodejs爬取b站番剧数据,并通过计算得出最佳追番推荐。通过调用相关接口获取番剧数据和评分数据,以及使用相应的算法进行计算。该方法可以帮助用户找到适合自己的番剧进行观看。 ... [详细]
  • 本文介绍了闭包的定义和运转机制,重点解释了闭包如何能够接触外部函数的作用域中的变量。通过词法作用域的查找规则,闭包可以访问外部函数的作用域。同时还提到了闭包的作用和影响。 ... [详细]
  • 本文介绍了在Vue项目中如何结合Element UI解决连续上传多张图片及图片编辑的问题。作者强调了在编码前要明确需求和所需要的结果,并详细描述了自己的代码实现过程。 ... [详细]
  • 本文详细介绍了如何使用MySQL来显示SQL语句的执行时间,并通过MySQL Query Profiler获取CPU和内存使用量以及系统锁和表锁的时间。同时介绍了效能分析的三种方法:瓶颈分析、工作负载分析和基于比率的分析。 ... [详细]
  • Ihavethefollowingonhtml我在html上有以下内容<html><head><scriptsrc..3003_Tes ... [详细]
  • 在编写业务代码时,常常会遇到复杂的业务逻辑导致代码冗长混乱的情况。为了解决这个问题,可以利用中间件模式来简化代码逻辑。中间件模式可以帮助我们更好地设计架构和代码,提高代码质量。本文介绍了中间件模式的基本概念和用法。 ... [详细]
  • 本文介绍了在wepy中运用小顺序页面受权的计划,包含了用户点击作废后的从新受权计划。 ... [详细]
  • 模板引擎StringTemplate的使用方法和特点
    本文介绍了模板引擎StringTemplate的使用方法和特点,包括强制Model和View的分离、Lazy-Evaluation、Recursive enable等。同时,还介绍了StringTemplate语法中的属性和普通字符的使用方法,并提供了向模板填充属性的示例代码。 ... [详细]
  • 本文讨论了一个关于正则的困惑,即为什么一个函数会获取parent下所有的节点。同时提出了问题是否是正则表达式写错了。 ... [详细]
  • 深入理解CSS中的margin属性及其应用场景
    本文主要介绍了CSS中的margin属性及其应用场景,包括垂直外边距合并、padding的使用时机、行内替换元素与费替换元素的区别、margin的基线、盒子的物理大小、显示大小、逻辑大小等知识点。通过深入理解这些概念,读者可以更好地掌握margin的用法和原理。同时,文中提供了一些相关的文档和规范供读者参考。 ... [详细]
  • 本文讨论了在openwrt-17.01版本中,mt7628设备上初始化启动时eth0的mac地址总是随机生成的问题。每次随机生成的eth0的mac地址都会写到/sys/class/net/eth0/address目录下,而openwrt-17.01原版的SDK会根据随机生成的eth0的mac地址再生成eth0.1、eth0.2等,生成后的mac地址会保存在/etc/config/network下。 ... [详细]
  • 本文介绍了一道网络流题目hdu4888 Redraw Beautiful Drawings的解题思路。题目要求以行和列作为结点建图,并通过最大流算法判断是否有解以及是否唯一。文章详细介绍了建图和算法的过程,并强调在dfs过程中要进行回溯。 ... [详细]
  • React项目中运用React技巧解决实际问题的总结
    本文总结了在React项目中如何运用React技巧解决一些实际问题,包括取消请求和页面卸载的关联,利用useEffect和AbortController等技术实现请求的取消。文章中的代码是简化后的例子,但思想是相通的。 ... [详细]
  • Spring常用注解(绝对经典),全靠这份Java知识点PDF大全
    本文介绍了Spring常用注解和注入bean的注解,包括@Bean、@Autowired、@Inject等,同时提供了一个Java知识点PDF大全的资源链接。其中详细介绍了ColorFactoryBean的使用,以及@Autowired和@Inject的区别和用法。此外,还提到了@Required属性的配置和使用。 ... [详细]
  • 本文介绍了一个React Native新手在尝试将数据发布到服务器时遇到的问题,以及他的React Native代码和服务器端代码。他使用fetch方法将数据发送到服务器,但无法在服务器端读取/获取发布的数据。 ... [详细]
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社区 版权所有