AngularJS 的全选、反选实现

一、需求

  • 要使用 AngularJS 实现 checkbox 的全选、反选。
  • 其中所有项都选中,则全选的 checkbox 也选中。
  • 有一项没有选中,全选的 checkbox 不选中。
  • 点击反选按钮,所有项反选,全选的checkbox 视情况而定,如果再所有项都没有选中的情况下反选等同于全选。

二、思路

  1. 需要获取全选 checkobx 的选中状态。
  2. 需要获取每个项 checkbox 的状态。
  3. 需要获取所有选中的 checkbox 的ng-model。
  4. 需要获取所有选项的数量。(用于和 3 进行比较,来判断是否全部选中)
  5. 需要获取反选按钮的状态,然后所有选中的 checkbox 的 ng-model 置反。

三、实现

  1. 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>
  2. 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;
    }
    }
    });
  3. 实现效果

AngularJS 的全选、反选实现的更多相关文章

  1. JavaScript、全选反选-课堂笔记

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  2. 关于input全选反选恶心的异常情况

    上一篇讲到:第一次点击全选按钮input显示对勾,第二次则不显示,需要用prop来添加checked属性. 但是用prop会出现一个问题,对勾显示,而checked属性不会被添加(比如:$(" ...

  3. jQuery全选/反选checkbox

    <!doctype html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  4. python: jquery实现全选 反选 取消

    引入这个jquery-1.12.4.js jquery实现全选 反选 取消 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitio ...

  5. BootStrapt iCheck表单美化插件使用方法详解(含参数、事件等) 全选 反选

    特色: 1.在不同浏览器(包括ie6+)和设备上都有相同的表现 — 包括 桌面和移动设备 2.支持触摸设备 — iOS.Android.BlackBerry.Windows Phone等系统 4.方便 ...

  6. 用javascript实现全选/反选组件

    以下是本人制作的全选/反选 组件,供广大同行参考.指正: 效果如图: 在实现的过程中,全选和全部取消选中这两个功能较为简单,只需用for循环遍历所有复选框为true或false即可.反选也较为简单,也 ...

  7. jquery、js操作checkbox全选反选

    全选反选checkbox在实际应用中比较常见,本文有个不错的示例,大家可以参考下 操作checkbox,全选反选//全选 function checkAll() { $('input[name=&qu ...

  8. jquery、js全选反选checkbox

    操作checkbox,全选反选 //全选 function checkAll() { $('input[name="TheID"]').attr("checked&quo ...

  9. Dom操作--全选反选

    我们经常会在网站上遇到一些多选的情况,下面我就来说说使用Dom写全选反选的思路. 全选思路:首先,我们来分析一下知道,当我们点击"全选"复选框的时候,所有的复选框应该都被选中,那我 ...

随机推荐

  1. iOS7的十个更“佳”:简洁直观更受青睐

    转自:http://www.25pp.com/news/news_27792.html iOS7自发布以来一直是褒贬不一,虽然苹果还只是发布了第二个测试版,但普通用户早已经在纠结到底该不该升级iOS7 ...

  2. maven 学习---Maven中央存储库

    当你建立一个 Maven 的项目,Maven 会检查你的 pom.xml 文件,以确定哪些依赖下载. 首先,Maven 将从本地资源库获得 Maven 的本地资源库依赖资源, 如果没有找到,然后把它会 ...

  3. 【LINQ】Select与SelectMany的区别

    Select() 和 SelectMany() 的工作都是依据源值生成一个或多个结果值.Select() 为每个源值生成一个结果值.因此,总体结果是一个与源集合具有相同元素数目的集合.与之相反,Sel ...

  4. spoon数据转换中文乱码(kettle)

    (1) 查看mysql数据库是否为utf8(status) (2) 设置spoon (3) 文本打开spoon.bat,找到set OPT=%OPT% %PENTAHO_DI_JAVA_OPTIONS ...

  5. 短uuid生成

    UUID UUID是128位的全局唯一标识符,通常由32字节的字符串表示.它可以保证时间和空间的唯一性,python中称为UUID,其他语言中可能称为GUID. 它通过MAC地址.时间戳.命名空间.随 ...

  6. 逆向破解之160个CrackMe —— 027

    CrackMe —— 027 160 CrackMe 是比较适合新手学习逆向破解的CrackMe的一个集合一共160个待逆向破解的程序 CrackMe:它们都是一些公开给别人尝试破解的小程序,制作 c ...

  7. django url注册器组件, 响应器组件, 分页器组件

    一.url注册器的使用 1.1导入模块 from django.urls import re_path, include from .serializer import views from rest ...

  8. MySql日期格式化(format)取值范围

  9. Browse Princeton's Series (by Date) in Princeton Economic History of the Western World

    Browse Princeton's Series (by Date) in Princeton Economic History of the Western World Joel Mokyr, S ...

  10. python基础之四:list、tuple

    一.列表 list # 列表 ''' 类似str,可以进行切片 ''' li = [', [1, 2, 3], 55, 'we all in ', 'Tom', ''] print(li[0:2]) ...