深究AngularJS——ng-checked(回写:带真实案例代码)


Posted in Javascript onJune 13, 2017

1.需求

在添加页面实现一个checkbox的选择,然后在详情页面展示时,会自动选上之前被选中的。

2.添加页面

看官最好将这个代码复制过去看看效果。

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script>
</head>
<body>
<div ng-app="myApp" ng-controller="myCtrl" >
  选择
  <div ng-repeat="item in list">
    <input type="checkbox" name="tagName" value="item.id" ng-click="select(item.id,$event)"> {{item.shortName}}
  </div>
  结果:{{result}}
</div>
<script>  
  var app = angular.module('myApp', []);
  app.controller('myCtrl', function($scope) {
    //创建checkbox用的
    $scope.list=[{"id":1,"shortName":"张三"},{"id":2,"shortName":"李四"},{"id":3,"shortName":"王二"}];
    //存储已选
    $scope.result = [];
    //触发事件
    $scope.select = function(id,event){      
      console.log(event)//打印看看这是什么,有利于理解
      console.log(action)

      var action = event.target;
      if(action.checked){//选中,就添加
        if($scope.result.indexOf(id) == -1){//不存在就添加
          $scope.result.push(id);
        }
      }else{//去除就删除result里
        var idx = $scope.result.indexOf(id);
        if( idx != -1){//不存在就添加
          $scope.result.splice(idx,1);
        }
      }
    };
  });
</script>
</body>
</html>

3.详情展示

//假设添加页面的结果是:$scope.result = [3,2];

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script>
</head>
<body>

<div ng-app="myApp" ng-controller="myCtrl" >
  回写时设置不可选,即设ng-disabled="true"
  <div ng-repeat="item in list">
    <input type="checkbox" name="tagName" ng-checked="isSelected(item.id)" value="item.id" ng-disabled="true" > {{item.shortName}}
  </div>
  结果:{{result}}
</div>

<script>  
  var app = angular.module('myApp', []);
  app.controller('myCtrl', function($scope) {
    //创建checkbox用的
    $scope.list=[{"id":1,"shortName":"张三"},{"id":2,"shortName":"李四"},{"id":3,"shortName":"王二"}];

    //在添加页面得到的结果
    //你会发现,顺序也不会影响结果
    $scope.result = [3,2];

    //被选中条件:ng-checked的结果为true
    $scope.isSelected = function(id){     
      return $scope.result.indexOf(id)!=-1; 
      //只要返回的结果为true,则对应的checkbox就会被选中,
      //所以我的思路是看存添加页面的结果里是否含有当前id即value值,
      //有就返回的true,没有就返回false
    };
  });
</script>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript 比较时间大小的代码
Apr 24 Javascript
一个很简单的jquery+xml+ajax的无刷新树结构(无css,后台是c#)
Jun 02 Javascript
js 幻灯片的实现
Dec 06 Javascript
快速掌握WordPress中加载JavaScript脚本的方法
Dec 17 Javascript
从0开始学Vue
Oct 27 Javascript
easyui-combobox 实现简单的自动补全功能示例
Nov 08 Javascript
jquery滚动条插件(可以自定义)
Dec 11 Javascript
彻底搞懂JavaScript中的apply和call方法(必看)
Sep 18 Javascript
bootstrap Table的一些小操作
Nov 01 Javascript
vue实现pdf文档在线预览功能
Nov 26 Javascript
js 计算月/周的第一天和最后一天代码
Feb 01 Javascript
使用JavaScript实现贪吃蛇游戏
Sep 29 Javascript
详解vue项目优化之按需加载组件-使用webpack require.ensure
Jun 13 #Javascript
javascript checkbox/radio onchange不能兼容ie8处理办法
Jun 13 #Javascript
angularjs之$timeout指令详解
Jun 13 #Javascript
JS实现json的序列化和反序列化功能示例
Jun 13 #Javascript
angularjs实现搜索的关键字在正文中高亮出来
Jun 13 #Javascript
angular-ngSanitize模块-$sanitize服务详解
Jun 13 #Javascript
让微信小程序支持ES6中Promise特性的方法详解
Jun 13 #Javascript
You might like
PHP中查询SQL Server或Sybase时TEXT字段被截断的解决方法
2009/03/10 PHP
PHP源码分析之变量的存储过程分解
2014/07/03 PHP
mongodb和php的用法详解
2019/03/25 PHP
飞鱼(shqlsl) javascript作品集
2006/12/16 Javascript
Javascript select控件操作大全(新增、修改、删除、选中、清空、判断存在等)
2008/12/19 Javascript
js 单引号 传递方法
2009/06/22 Javascript
javascript下4个跨浏览器必备的函数
2010/03/07 Javascript
基于jQuery的一个扩展form序列化到json对象
2010/12/09 Javascript
Javascript中作用域的详细介绍
2016/10/06 Javascript
Bootstrap轮播插件使用代码
2016/10/11 Javascript
js字符串操作总结(必看篇)
2016/11/22 Javascript
JQuery和PHP结合实现动态进度条上传显示
2016/11/23 Javascript
JS对象与JSON互转换、New Function()、 forEach()、DOM事件流等js开发基础小结
2017/08/10 Javascript
JavaScript学习笔记之函数记忆
2017/09/06 Javascript
快速搭建vue2.0+boostrap项目的方法
2018/04/09 Javascript
微信小程序显示倒计时功能示例【测试可用】
2018/12/03 Javascript
vue中改变滚动条样式的方法
2020/03/03 Javascript
Python中的类学习笔记
2014/09/23 Python
Python连接数据库学习之DB-API详解
2017/02/07 Python
基于python爬虫数据处理(详解)
2017/06/10 Python
python 读入多行数据的实例
2018/04/19 Python
使用python实现离散时间傅里叶变换的方法
2019/09/02 Python
详解Python 中的 defaultdict 数据类型
2021/02/22 Python
Django实现简单的分页功能
2021/02/22 Python
Linux的文件类型
2012/03/07 面试题
商务英语求职自荐信范文
2013/12/24 职场文书
预备党员入党思想汇报
2014/01/04 职场文书
物业工作计划书
2014/01/10 职场文书
农村婚礼证婚词
2014/01/10 职场文书
汉语言文学职业规划
2014/02/14 职场文书
幼儿园优秀班主任事迹材料
2014/05/14 职场文书
暑期社会实践先进个人主要事迹
2014/05/22 职场文书
幼师求职自荐信
2014/05/31 职场文书
驻村工作先进事迹
2014/08/14 职场文书
领导干部群众路线教育实践活动个人对照检查材料
2014/09/23 职场文书
大学生安全教育心得体会
2016/01/15 职场文书