AngularJs ng-change事件/指令的用法小结
程序员文章站
2022-06-25 13:43:39
本文介绍了angularjs ng-change事件/指令的小结,分享给大家,也给自己留个笔记
定义和用法
ng-change 指令用于告诉 angularjs 在...
本文介绍了angularjs ng-change事件/指令的小结,分享给大家,也给自己留个笔记
定义和用法
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 | 元素值改变时执行表达式。 |
实例说明:当输入框的值改变时执行函数:
<body ng-app="myapp"> <div ng-controller="myctrl"> <input type="text" ng-change="myfunc()" ng-model="myvalue" /> <p>the input field has changed {{count}} times.</p> </div> <script> angular.module('myapp', []) .controller('myctrl', ['$scope', function($scope) { $scope.count = 0; $scope.myfunc = function() { $scope.count++; }; }]); </script> </body>
实例说明,radio和checkbox
注:checkbox ng-model总是是true或false,而不是value,其他的ng-model默认都是value 的值
html
<h3>radio 控件测试</h3> <p><label> <input type="radio" value="男" name="sex" ng-model="value1" ng-change="radiochecked()" /> 男 </label> <label> <input type="radio" value="女" name="sex" ng-model="value1" ng-change="radiochecked()" /> 女 </label></p> <h3>checked 控件测试</h3> <p><div class="checkbox"> <label> <input name="agree" type="checkbox" value="同意" ng-model="value2" ng-change="checkboxclick()" /> 同意协议 </label> </div> <div class="checkbox"> <label> <input name="agree" type="checkbox" value="同意2" ng-model="value2" ng-change="checkboxclick()" /> 同意协议2 </label> </div></p>
js:
var app = angular.module('myapp', []); app.controller('validatectrl', function ($scope) { //randio ng-change事件和原始onchange相同 //radio ng-model 的值是value $scope.radiochecked = function () { console.info($scope.value1); } //checkbox ng-change事件和原始onchange相同 //checkbox ng-model总是是true或false $scope.checkboxclick = function () { console.info($scope.value2); } });
实例说明,text,select
html
<form class="form-horizontal"> <div class="form-group"> <label class="control-label">姓名:</label> <input type="text" class="form-control" ng-model="name" ng-change="txtchange();" /> </div> <div class="form-group"> <label class="control-label">选择年级:</label> <select class="form-control" ng-change="selectchange();" ng-model="grade"> <option value="1">一年级</option> <option value="2">二年级</option> </select> </div> </form>
js
var app = angular.module('myapp', []); app.controller('validatectrl', function ($scope) { //textbox 的ng-change事件和原始ng-change不相同,而是和$scope.$watch()监听相同 //textbox 的ng-model为当前输入框的内容,为value值 $scope.txtchange = function () { console.info($scope.name); } //select 的ng-change事件和原始ng-change相同 //ng-model 的默认情况下ng-model的结果为value值 $scope.selectchange = function () { console.info($scope.grade); } });
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
推荐阅读
-
解决angularJS中input标签的ng-change事件无效问题
-
AngularJS中directive指令使用之事件绑定与指令交互用法示例
-
angularJs的事件处理指令测试和代码整理
-
解决angularJS中input标签的ng-change事件无效问题
-
Angularjs 动态添加指令并绑定事件的方法
-
Angularjs中使用指令绑定点击事件的方法
-
AngularJS ng-change 指令的详解及简单实例
-
关于Angularjs中自定义指令一些有价值的细节和技巧小结
-
AngularJs ng-change事件/指令的用法小结
-
AngularJS中directive指令使用之事件绑定与指令交互用法示例