AngularJS学习之路——过滤器(2)

自定义过滤器

angular.module('filterApp',[])
.filter('myFilter',function(){
  return function(input){
    /* input就是需要过滤的内容 */
  }
})

表单验证

input上所有的验证项:

1. 必填项

验证某个表单输入是否已填写,只要在输入字段元素上添加HTML5标记required即可:


2. 最小长度

验证表单输入的文本长度是否大于某个最小值,在输入字段上使用AngularJS指令ng-minleng="{number}":


3. 最大长度

验证表单输入的文本长度是否小于或等于某个最大值,在输入字段上使用AngularJS指令ng-maxlength="{number}":


4. 模式匹配

使用ng-pattern="/PATTERN/"来确保输入能够匹配指定的正则表达式:


5. 电子邮件

验证输入内容是否是电子邮件,只要像下面这样将input的类型设置为email即可:


6. 数字

验证输入内容是否是数字,将input的类型设置为number:


7. URL

验证输入内容是否是URL,将input的类型设置为 url:


8.在表单中控制变量

表单的属性可以在其所属的$scope对象中访问到,而我们又可以访问$scope对象,因此JavaScript可以间接地访问DOM中的表单属性。借助这些属性,我们可以对表单做出实时(和AngularJS中其他东西一样)响应。这些属性包括下面这些。

  • 未修改的表单
    这是一个布尔属性,用来判断用户是否修改了表单。如果未修改,值为true,如果修改过值为false:
    formName.inputFieldName.$pristine

  • 修改过的表单
    只要用户修改过表单,无论输入是否通过验证,该值都返回true:
    formName.inputFieldName.$dirty

  • 合法的表单
    这个布尔型的属性用来判断表单的内容是否合法。如果当前表单内容是合法的,下面属性的值就是true:
    formName.inputFieldName.$valid

  • 不合法的表单
    这个布尔属性用来判断表单的内容是否不合法。如果当前表单内容是不合法的,下面属性的值为true:
    formName.inputFieldName.$invalid

  • 错误
    这是AngularJS提供的另外一个非常有用的属性:$error对象。它包含当前表单的所有验证内容,以及它们是否合法的信息。用下面的语法访问这个属性:
    formName.inputfieldName.$error

AngularJS处理表单时,会根据表单当前的状态添加一些CSS类:
.ng-pristine {}
.ng-dirty {}
.ng-valid {}
.ng-invalid {}

你可能感兴趣的:(AngularJS学习之路——过滤器(2))