from:http://blog.csdn.net/u011127019/article/details/52564111

定义和用法

ng-change 指令用于告诉 AngularJS 在 HTML 元素值改变时需要执行的操作。

ng-change 指令需要搭配 ng-model 指令使用。

AngularJS ng-change 指令指令不会覆盖原生的 onchange 事件, 如果触发该事件,ng-change 表达式与原生的 onchange 事件都会执行。

ng-change 事件在值的每次改变时触发,它不需要等待一个完成的修改过程,或等待失去焦点的动作。

ng-change 事件只针对输入框值的真实修改,而不是通过 JavaScript 来修改。


语法

<element ng-change="expression"></element>

<input>, <select>, 和  <textarea> 元素支持。

<radio>,<checkbox>


参数值

描述
expression 元素值改变时执行表达式。

实例说明,radio和checkbox

注:checkbox ng-model总是是true或false,而不是value,其他的ng-model默认都是value 的值

HTML

  1. <h3>Radio 控件测试</h3>
  2. <p><label>
  3. <input type="radio" value="男" name="sex" ng-model="value1" ng-change="radioChecked()" />
  4. </label>
  5. <label>
  6. <input type="radio" value="女" name="sex" ng-model="value1" ng-change="radioChecked()" />
  7. </label></p>
  8. <h3>checked 控件测试</h3>
  9. <p><div class="checkbox">
  10. <label>
  11. <input name="agree" type="checkbox" value="同意" ng-model="value2" ng-change="checkboxClick()" />
  12. 同意协议
  13. </label>
  14. </div>
  15. <div class="checkbox">
  16. <label>
  17. <input name="agree" type="checkbox" value="同意2" ng-model="value2" ng-change="checkboxClick()" />
  18. 同意协议2
  19. </label>
  20. </div></p>

JS:

[javascript] view plain copy

print?

  1. var app = angular.module('myApp', []);
  2. app.controller('validateCtrl', function ($scope) {
  3. //randio ng-change事件和原始onchange相同
  4. //radio ng-model 的值是value
  5. $scope.radioChecked = function () {
  6. console.info($scope.value1);
  7. }
  8. //checkbox ng-change事件和原始onchange相同
  9. //checkbox ng-model总是是true或false
  10. $scope.checkboxClick = function () {
  11. console.info($scope.value2);
  12. }
  13. });

实例说明,text,select

HTML

  1. <form class="form-horizontal">
  2. <div class="form-group">
  3. <label class="control-label">姓名:</label>
  4. <input type="text" class="form-control" ng-model="name" ng-change="txtChange();" />
  5. </div>
  6. <div class="form-group">
  7. <label class="control-label">选择年级:</label>
  8. <select class="form-control" ng-change="selectChange();" ng-model="grade">
  9. <option value="1">一年级</option>
  10. <option value="2">二年级</option>
  11. </select>
  12. </div>
  13. </form>

JS

[javascript] view plain copy

print?

  1. var app = angular.module('myApp', []);
  2. app.controller('validateCtrl', function ($scope) {
  3. //textbox 的ng-change事件和原始ng-change不相同,而是和$scope.$watch()监听相同
  4. //textbox 的ng-model为当前输入框的内容,为value值
  5. $scope.txtChange = function () {
  6. console.info($scope.name);
  7. }
  8. //select 的ng-change事件和原始ng-change相同
  9. //ng-model 的默认情况下ng-model的结果为value值
  10. $scope.selectChange = function () {
  11. console.info($scope.grade);
  12. }
  13. });

AngularJs ng-change事件/指令(转)的更多相关文章

  1. angularjs学习笔记—事件指令

    ngClick 适用标签:所有触发条件:单击 #html <div ng-controller="LearnCtrl"> <div ng-click=" ...

  2. AngularJS1.X学习笔记4-内置事件指令及其他

    AngularJS为我们定义了一系列事件指令,方便我们对用户的操作作出响应.甚至他还有一个可选模块提供了触摸事件和手势事件的支持,为移动端开发提供了可能.现在开始学习一下AngularJS的事件指令. ...

  3. ng之自定义指令

    最近开始研究并使用angular,今天就来简单讲讲对于ng中自定义指令的一下使用心得吧! 相信用过ng的人都对ng中的指令有所了解,指令,我将其理解为AngularJS操作HTML element的一 ...

  4. AngularJS HTML DOM& 事件

    AngularJS 为 HTML DOM 元素的属性提供了绑定应用数据的指令. ng-disabled 指令直接绑定应用程序数据到 HTML 的 disabled 属性 <div ng-app= ...

  5. AngularJS 学习之事件

    1.ng-click指令:定义了AngularJS点击事件 <div ng-app="" ng-controller="myCtrl"> <b ...

  6. angularjs的touch事件

    angularJs没有touch事件.这里提供一个touch指令. ngTouch.js "use strict"; angular.module("ngTouch&qu ...

  7. Ⅶ.AngularJS的点点滴滴-- 事件

    事件(和js一样有冒泡和捕获) <html> <script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.2 ...

  8. angularjs directive and component 指令与组件 ( 1.5.0 以后 )

    之前写过一篇了 http://www.cnblogs.com/keatkeat/p/3903673.html 但某些部分写的不太清楚,甚至有点错误,所以今天特地在这里再来谈谈. 这篇主要是说指令的隔离 ...

  9. 带你走近AngularJS - 创建自己定义指令

    带你走近AngularJS系列: 带你走近AngularJS - 基本功能介绍 带你走近AngularJS - 体验指令实例 带你走近AngularJS - 创建自己定义指令 ------------ ...

  10. 带你走近AngularJS 之创建自定义指令

    带你走近AngularJS 之创建自定义指令 为什么使用AngularJS 指令? 使用过 AngularJS 的朋友应该最感兴趣的是它的指令.现今市场上的前端框架也只有AngularJS 拥有自定义 ...

随机推荐

  1. page 页 分页 分段

    小结: 1. 页:磁盘和内存间传输数据的最小单位: MySQL: What is a page? https://stackoverflow.com/questions/4401910/mysql-w ...

  2. [dpdk] TSC , HPET, Timer, Event Timer,RDTSCP

    关于dpdk timer跨越CPU core调度的准确性问题 首先dpdk的timer接口里边使用 cpu cycle来比较时间.根据之前的内容 [dpdk] dpdk --lcores参数 当一个E ...

  3. [knowledge][lisp] lisp与AI

    https://blog.youxu.info/2009/08/31/lisp-and-ai-1/ https://blog.youxu.info/2010/02/10/lisp-and-ai-2/

  4. idea找不到import project

    一.首先File->close project 关完后,在界面你就可以看到import project

  5. jquery 数组的操作

    1.数组的创建 var arrayObj = new Array(); //创建一个数组 var arrayObj = new Array([size]); //创建一个数组并指定长度,注意不是上限, ...

  6. 洛谷P3295 萌萌哒 [SCOI2016] 倍增+并查集

    正解:倍增+并查集 解题报告: 传送门! 首先不难想到暴力?就考虑把区间相等转化成对应点对相等,然后直接对应点连边,最后求有几个连通块就好辣 然后看下复杂度,修改是O(n2)查询是O(n),就比较容易 ...

  7. Phone list(Trie树模板)

    Phone List 共t组数据,给定n个长度不超过10的字符串,问其中是否存在两个数S,T,使得S是T的前缀. 存在则输出NO,不存在输出YES 输入样例#1: 2 3 911 97625999 9 ...

  8. kvo观察实例变量

    // 手动设定KVO - (void)setAge:(NSString *)age { [self willChangeValueForKey:@"age"]; _age = ag ...

  9. python-面向对象-03_面向对象基础语法

    面向对象基础语法 目标 dir 内置函数 定义简单的类(只包含方法) 方法中的 self 参数 初始化方法 内置方法和属性 01. dir 内置函数(知道) 在 Python 中 对象几乎是无所不在的 ...

  10. darknet的安装及报错解决

    darknet 是YOLO网络的一个框架,安装见官网:https://pjreddie.com/darknet/ 跟着步骤就可以安装好了. 由于官网是全英文的,所以本文根据官网进行中文释义. 本人在按 ...