<input type="number" name="age" ng-model="user.age" />
7. URL
验证输入内容是否是URL,将 input 的类型设置为 url :
<input type="url" name="homepage" ng-model="user.facebook_url" />
在表单中控制变量
表单的属性可以在其所属的 $scope 对象中访问到,而我们又可以访问 $scope 对象,因此JavaScript可以间接地访问DOM中的表单属性。借助这些属性,我们可以对表单做出实时(和AngularJS中其他东西一样)响应。这些属性包括下面这些。(注意,可以使用下面的格式访问这些属性。)
formName.inputFieldName.property
■未修改的表单
这是一个布尔属性,用来判断用户是否修改了表单。如果未修改,值为 true ,如果修改过值为 false
formName.inputFieldName.$pristine
■修改过的表单
只要用户修改过表单,无论输入是否通过验证,该值都返回 true
formName.inputFieldName.$dirty
■合法的表单
这个布尔型的属性用来判断表单的内容是否合法。如果当前表单内容是合法的,下面属性的值就是 true :
formName.inputFieldName.$valid
■ 不合法的表单
这个布尔属性用来判断表单的内容是否不合法。如果当前表单内容是不合法的,下面属性的值为 true :
formName.inputFieldName.$invalid
■ 错误
这是AngularJS提供的另外一个非常有用的属性: $error 对象。它包含当前表单的所有验证内容,以及它们是否合法的信息。用下面的语法访问这个属性:
formName.inputfieldName.$error
$parsers
当用户同控制器进行交互,并且 ngModelController 中的 $setViewValue() 方法被调用时,$parsers 数组中的函数会以流水线的形式被逐个调用。第一个 $parse 被调用后,执行结果会传递给第二个 $parse ,以此类推
这些函数可以对输入值进行转换,或者通过 $setValidity() 函数设置表单的合法性。
使用 $parsers 数组是实现自定义验证的途径之一。
例如,假设我们想要确保输入值在某两个数值之间,可以在 $parsers 数组中入栈一个新的函数,这个函数会在验证链中被调用。
每个 $parser 返回的值都会被传入下一个 $parser 中。当不希望数据模型发生更新时返回undefined 。
html
<!DOCTYPE html> <html ng-app="myApp"> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <title>表单测试</title> <link rel="stylesheet" href=""> <script type="text/javascript" src="angular.1.2.13.js"></script> </head> <body> <div ng-controller="TestController"> <form name="testForm"> <input type="number" name="inputs" ng-test ng-model="obj.number"> <span ng-show="testForm.inputs.$error.test">good</span> <span ng-hide="testForm.inputs.$error.test">bad</span> <div>{{ testForm.inputs.$valid }}</div> <div>{{ testForm.inputs.$invalid }}</div> <div>{{ obj.number }}</div> </form> </div> <script type="text/javascript" src="test5app.js"></script> </body> </html>
内容版权声明:除非注明,否则皆为本站原创文章。