美文网首页
AngularJS学习之路——过滤器(2)

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

作者: lemonade_a | 来源:发表于2017-10-20 10:32 被阅读7次

自定义过滤器

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

表单验证

input上所有的验证项:

1. 必填项

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

<input type="text" required />

2. 最小长度

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

<input type="text" ng-minlength="5" />

3. 最大长度

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

<input type="text" ng-maxlength="20" />

4. 模式匹配

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

<input type="text" ng-pattern="[a-zA-Z]" />

5. 电子邮件

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

<input type="email" name="email" ng-model="user.email" />

6. 数字

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

<input type="number" name="age" ng-model="user.age" />

7. URL

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

<input type="url" name="homepage" ng-model="user.facebook_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)

      本文链接:https://www.haomeiwen.com/subject/hhymuxtx.html