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