AngularJS 模型详细介绍及实例代码
AngularJSng-model指令
ng-model指令用于绑定应用程序数据到HTML控制器(input,select,textarea)的值。
ng-model指令
ng-model指令可以将输入域的值与AngularJS创建的变量绑定。
AngularJS实例
<!DOCTYPEhtml> <html> <head> <metacharset="utf-8"> <scriptsrc="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script> </head> <body> <divng-app="myApp"ng-controller="myCtrl"> 名字:<inputng-model="name"> </div> <script> varapp=angular.module('myApp',[]); app.controller('myCtrl',function($scope){ $scope.name="JohnDoe"; }); </script> <p>使用ng-model指令来绑定输入域的值到控制器的属性。</p> </body> </html>
运行结果:
名字:使用ng-model指令来绑定输入域的值到控制器的属性。
双向绑定
双向绑定,在修改输入域的值时,AngularJS属性的值也将修改:
AngularJS实例
<!DOCTYPEhtml> <html> <head> <metacharset="utf-8"> <scriptsrc="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script> </head> <body> <divng-app="myApp"ng-controller="myCtrl"> 名字:<inputng-model="name"> <h1>你输入了:{{name}}</h1> </div> <script> varapp=angular.module('myApp',[]); app.controller('myCtrl',function($scope){ $scope.name="JohnDoe"; }); </script> <p>修改输入框的值,标题的名字也会相应修改。</p> </body> </html>
运行结果:
名字:
你输入了:JohnDoe
修改输入框的值,标题的名字也会相应修改。
验证用户输入
AngularJS实例
<!DOCTYPEhtml> <html> <head> <metacharset="utf-8"> <scriptsrc="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script> </head> <body> <formng-app=""name="myForm"> Email: <inputtype="email"name="myAddress"ng-model="text"> <spanng-show="myForm.myAddress.$error.email">不是一个合法的邮箱地址</span> </form> <p>在输入框中输入你的邮箱地址,如果不是一个合法的邮箱地址,会弹出提示信息。</p> </body> </html>
运行结果:
Email:
在输入框中输入你的邮箱地址,如果不是一个合法的邮箱地址,会弹出提示信息。
CSS类
ng-model指令基于它们的状态为HTML元素提供了CSS类:
AngularJS实例
<!DOCTYPEhtml> <html> <head> <metacharset="utf-8"> <scriptsrc="http://apps.bdimg.com/libs/angular.js/1.4.6/angular.min.js"></script> <style> input.ng-invalid{ background-color:lightblue; } </style> </head> <body> <formng-app=""name="myForm"> 输入你的名字: <inputname="myName"ng-model="myText"required> </form> <p>编辑文本域,不同状态背景颜色会发送变化。</p> <p>文本域添加了required属性,该值是必须的,如果为空则是不合法的。</p> </body> </html>
运行结果:
编辑文本域,不同状态背景颜色会发送变化。
文本域添加了required属性,该值是必须的,如果为空则是不合法的。
ng-model指令根据表单域的状态添加/移除以下类:
ng-empty
ng-not-empty
ng-touched
ng-untouched
ng-valid
ng-invalid
ng-dirty
ng-pending
ng-pristine