AngularJS 的全选、反选实现
AngularJS 的全选、反选实现
一、需求
- 要使用 AngularJS 实现 checkbox 的全选、反选。
- 其中所有项都选中,则全选的 checkbox 也选中。
- 有一项没有选中,全选的 checkbox 不选中。
- 点击反选按钮,所有项反选,全选的checkbox 视情况而定,如果再所有项都没有选中的情况下反选等同于全选。
二、思路
- 需要获取全选 checkobx 的选中状态。
- 需要获取每个项 checkbox 的状态。
- 需要获取所有选中的 checkbox 的ng-model。
- 需要获取所有选项的数量。(用于和 3 进行比较,来判断是否全部选中)
- 需要获取反选按钮的状态,然后所有选中的 checkbox 的 ng-model 置反。
三、实现
index.html
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>全选与反选Demo</title>
<script src="js/angular.min.js"></script>
<script src="js/index.js"></script>
</head>
<body ng-app="demo" ng-controller="indexController" >
<ul>
<li><input type="checkbox" ng-model="sellect_all" ng-click="selectAll($event, list)">全选 <input type="button" ng-model="invert_all" ng-click="invertAll($event, list)" value="反选"></li>
<li ng-repeat="entity in list">
<input type="checkbox" ng-model="select_one[entity.id]" ng-click="selectOne($event,entity.id, list)">{{entity.value}}
</li>
</ul>
</body>
</html>
index.js
var app = angular.module('demo',[]); app.controller("indexController",function($scope){
// 自定义数据列表
$scope.list = [{"id": "1","value": "a"},{"id": "2","value": "b"},
{"id": "3","value": "c"},{"id": "4","value": "d"},
{"id": "5","value": "e"}]; $scope.selectIds=[];// 选中的ID集合
$scope.select_one=[]; // 单项是否选中状态集合,以 [{"1":true}...] 的方式存在,实际开发中,id 可能不是数字
$scope.sellect_all = false; // 全选按钮是否选中
$scope.invert_all = false; // 反选按钮是否选中 // 全选功能
$scope.selectAll = function($event, list) {
// 因为绑定的 sellect_all 有滞后,所以让其等于 $event.target.checked
$scope.sellect_all = $event.target.checked; if ($scope.sellect_all) {
angular.forEach(list, function(value) {
$scope.selectIds.push(value.id);
$scope.select_one[value.id] = true;
})
} else {
// 实现全不选功能
$scope.selectIds=[];
$scope.select_one=[];
}
} // 反选功能
$scope.invertAll = function($event, list) {
$scope.invert_all = $event.target.checked;
// 实现反选功能
$scope.selectIds=[];
angular.forEach(list, function(value) {
$scope.select_one[value.id] = !$scope.select_one[value.id];
if ($scope.select_one[value.id]) {
$scope.selectIds.push(value.id);
}
})
checkAll();
} // 单项checkbox选择功能
$scope.selectOne = function($event, id, list) {
if($event.target.checked){//如果是被选中,则增加到数组
$scope.selectIds.push( id);
}else{
var idx = $scope.selectIds.indexOf(id);
$scope.selectIds.splice(idx, 1);//删除
}
checkAll();
} // 检查是否全选
checkAll = function() {
// 如果按钮已全部被选,就使全选按钮选中,之所以进行非0判断,是考虑到了在实际环境中数据是服务器响应的。
if ($scope.selectIds.length != 0 && $scope.list.length == $scope.selectIds.length) {
$scope.sellect_all = true;
} else {
// 如果有的按钮没有被选中,就取消全选
$scope.sellect_all = false;
}
}
});
实现效果



AngularJS 的全选、反选实现的更多相关文章
- JavaScript、全选反选-课堂笔记
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 关于input全选反选恶心的异常情况
上一篇讲到:第一次点击全选按钮input显示对勾,第二次则不显示,需要用prop来添加checked属性. 但是用prop会出现一个问题,对勾显示,而checked属性不会被添加(比如:$(" ...
- jQuery全选/反选checkbox
<!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- python: jquery实现全选 反选 取消
引入这个jquery-1.12.4.js jquery实现全选 反选 取消 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitio ...
- BootStrapt iCheck表单美化插件使用方法详解(含参数、事件等) 全选 反选
特色: 1.在不同浏览器(包括ie6+)和设备上都有相同的表现 — 包括 桌面和移动设备 2.支持触摸设备 — iOS.Android.BlackBerry.Windows Phone等系统 4.方便 ...
- 用javascript实现全选/反选组件
以下是本人制作的全选/反选 组件,供广大同行参考.指正: 效果如图: 在实现的过程中,全选和全部取消选中这两个功能较为简单,只需用for循环遍历所有复选框为true或false即可.反选也较为简单,也 ...
- jquery、js操作checkbox全选反选
全选反选checkbox在实际应用中比较常见,本文有个不错的示例,大家可以参考下 操作checkbox,全选反选//全选 function checkAll() { $('input[name=&qu ...
- jquery、js全选反选checkbox
操作checkbox,全选反选 //全选 function checkAll() { $('input[name="TheID"]').attr("checked&quo ...
- Dom操作--全选反选
我们经常会在网站上遇到一些多选的情况,下面我就来说说使用Dom写全选反选的思路. 全选思路:首先,我们来分析一下知道,当我们点击"全选"复选框的时候,所有的复选框应该都被选中,那我 ...
随机推荐
- C++运算符重载学习总结
在C ++中,我们可以使运算符适用于用户定义的类. 这意味着C ++能够为运算符提供数据类型的特殊含义,这种能力称为运算符重载. 例如,我们可以在像String这样的类中重载运算符'+',这样我们就可 ...
- 在verilog中使用格雷码
格雷码的一些知识: https://baike.baidu.com/item/%E6%A0%BC%E9%9B%B7%E7%A0%81/6510858?fr=aladdin 绿色框起来的是0--15的格 ...
- disable_function绕过--利用LD_PRELOAD
0x00 前言 有时候直接执行命令的函数被ban了,那么有几种思路可以bypass 1.使用php本身自带的能够调用外部程序的函数 2.使用第三方插件入(如imagick) 但是这两种无非就是利用ph ...
- mysql 多条数据中,分组获取值最大的数据记录
摘要: 多条纪录中,几个字段相同,但是其中一个或者多个字段不同,则去该字段最大(这里只有一个不同) 源数据: 目的是移除:在同一天中只能存在一天数据,则取审核日期最大,数据库脚本如下: SELECT ...
- 【Spring AOP】Spring AOP之你必须知道的AOP相关概念(1)
一.什么是AOP AOP(Aspect-oriented Programming)即面向切面编程,是对OOP( Object-oriented Programming)即面向对象编程的一种补充,AOP ...
- Fork/Join框架与Java8 Stream API 之并行流的速度比较
Fork/Join 框架有特定的ExecutorService和线程池构成.ExecutorService可以运行任务,并且这个任务会被分解成较小的任务,它们从线程池中被fork(被不同的线程执行)出 ...
- Nginx 高级配置-压缩功能
Nginx 高级配置-压缩功能 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.Nginx压缩相关参数概述 1>.gzip on | off; Nginx支持对指定类型的文 ...
- Python的字符串与字节码转换
一张图弄懂python的字符串与字节码转换
- Linux服务器PHP后门查杀
shell脚本一句话查找PHP一句话木马 # find ./ -name "*.php" |xargs egrep "phpspy|c99sh|milw0rm|eval( ...
- [转]【EL表达式】11个内置对象(用的少) & EL执行表达式
1.EL的内置对象 其他不用记,红色记一下 代码: 2.EL执行表达式