AngularJS中使用的表单验证

前端之家收集整理的这篇文章主要介绍了AngularJS中使用的表单验证前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

客户端表单验证是AngularJS里面最酷的功能之一。 AngularJS表单验证可以让你从一开始就写出一个具有交互性和可相应的现代HTML5表单。

在AngularJS中,有许多表单验证指令。在这里,我们将谈谈几个最流行指令,然后我们将讨论如何编写自定义的验证。

<form name="form">
  label "email"Your email</labelinput type"email" ng-modelplaceholder"Email Address" />
form

AngularJS使得我们可以在不用额外努力的情况下轻松的处理客户端表单验证。虽然我们不能仅靠客户端验证来保持我们的Web应用程序的安全性,但他们提供了良好即时反馈到表单上。

要使用表单验证,我们首先必须确保form标签有一个name属性,像上面的例子一样。明白了吗?太好了!

所有输入字段可以进行一些基本的验证,例如最小长度,最大长度,等等,这些都是HTML5标签属性验证。

通常需要在form标签加上novalidate属性,这将禁用浏览器自带的验证功能,从而使用AngularJS提供的验证。

让我们来看看我们可以在input设置哪些验证:

必填

验证是否已输入字符,只需在标签加上required

"text"required

最小长度

验证输入至少输入{number}个字符,使用AngularJS指令的ng-minlength=“{number}”

ng-minlength5 最大长度

验证输入字符要小于等于{number}个字符,使用AngularJS指令的ng-maxlength=“{number}”

ng-maxlength20 正则匹配

要确保输入匹配一个正则表达式,使用AngularJS的指令ng-pattern="/PATTERN/":

ng-pattern"/a-zA-Z/" Email

验证输入字符是一个电子邮件地址,只需设定inputtype属性email,像这样:

"user.email" 数字

验证输入字符是一个数字,同样只需设定number,像这样:

"number""user.age" Url

验证输入字符是一个URL地址,同样只需设定url,像这样:

"url""homepage""user.facebook_url" 自定义验证

AngularJS可以很容易的使用指令来添加自定义验证。例如,我们要验证我们的用户名是可用的(在数据库中不重复)。要做到这一点,我们将实现一个指令,它在输入字符变化时触发一个Ajax请求:

var app = angular.module('validationExample',[]);

app.directive('ensureUnique',['$http',function($http) {
  return {
    require: 'ngModel'(scope,ele,attrs,c) {
      scope.$watch(attrs.ngModel,() {
        $http({
          method: 'POST''/api/check/' + attrs.ensureUnique,data: {'field': attrs.ensureUnique}
        }).success((data,status,headers,cfg) {
          c.$setValidity('unique''unique',51); font-weight:bold">false);
        });
      });
    }
  }
}]);

验证表单状态

AngularJS将DOM验证的结果保存在$scope对象中。这使我们能够实时做出一些响应。提供给我们的属性有:

请注意,这是这个属性的格式:

formName.inputFieldName.property

修改过的表单

布尔值属性,表示用户是否修改了表单。如果为ture,表示没有修改过;false表示修改过:

formName.inputFieldName.$pristine;

修改的表单

布尔型属性,当且仅当用户实际已经修改的表单。不管表单是否通过验证:

$dirty

经过验证的表单

布尔型属性,它指示表单是否通过验证。如果表单当前通过验证,他将为true

$valid

未通过验证的表单

布尔型属性,它指示表单是否通过验证。如果表单当前没有通过验证,他将为true:

$invalid

最后两个属性在用于DOM元素的显示或隐藏时是特别有用的。同时,如果要设置特定的class时,他们也非常有用的。

错误

另一个有用的属性是AngularJS提供给我们的$error对象。这个对象包含input的每一个验证是有效的还是无效的(一个集合)。为了访问这个属性,使用下面的语法:

formName.inputfieldName.$error

如果验证失败,则此属性将是true的,而如果它是false的,那么该值通过验证的。

无害的一些样式

当AngularJS处理的表单验证时,它将根据验证的状态增加一些特定的class属性。这些class被命名为类似的属性,我们可以检查。

.ng-pristine {}
.ng-dirty {}.ng-valid {}.ng-invalid {}

这些class对应着其对应的验证对象的结果。

当一个字段是无效的,.ng-invalid将被应用到这个字段上。我们可以通过css来设置这些class的样式:

input.ng-invalid { border: 1px solid red; } .ng-valid {1px solid green; }

全部放在一起

让我们编写一个注册表单。本申请表单将包括这个人的名字,他们的电子邮件,以及所需的用户名

让我们定义一个form表单:

"signup_form"novalidate ng-submit"signupForm()"fieldset legendSignup button "submit"class"button radius"Submitbutton 这个表单的名字是signup_form,当我们点击提交时我们将调用signupForm()方法.

现在,让我们添加用户Name属性:

div "row""large-12 columns"Your name"Name""name""signup.name"3 20 div 首先我想说明我使用了Foundation作为我的css框架,所以你将在代码中看到它的相关语法。 我们增加了一个名字为name的输入框,并且对象绑定在$scope对象的signup.name对象上(通过ng-model)。

我们还设置了几个验证。这些验证分别是:我们必须有一个长度为3个或更多字符的名字。并且最大长度限制为20个字符(21或更多的个字符将是无效的)。最后,我们设置名称应该是必填的。

当如果表单无效时,让我们用属性来控制显示还是隐藏错误列表。我们还将使用$dirty属性,以确保当用户没有输入字符前错误提示不显示

"error"ng-show"signup_form.name.$dirty && signup_form.name.$invalid"small "signup_form.name.$error.required" Your name is required. small"signup_form.name.$error.minlength" Your name is required to be at least 3 characters "signup_form.name.$error.maxlength" Your name cannot be longer than 20 characters

让我们来看看接下来的验证,一个电子邮件:

"Email""signup.email""signup_form.email.$dirty && signup_form.email.$invalid" "signup_form.email.$error.required" Your email is required. "signup_form.email.$error.minlength" Your email is required to be at least 3 characters "signup_form.email.$error.email" That is not a valid email. Please input a valid email. "signup_form.email.$error.maxlength" Your email cannot be longer than 20 characters

这一次(包括整个表单),我们编写电子邮件字段。请注意,我们设置了input的type属性为email并且添加$error.email错误信息。这是基于AngularJS的电子邮件验证(使用HTML5的属性)。

最后,让我们来看看在我们的最后一个输入框,用户名

Username"Desired username""username""signup.username"ensure-unique"signup_form.username.$dirty && signup_form.username.$invalid""signup_form.username.$error.required"Please input a username"signup_form.username.$error.minlength"Your username is required to be at least 3 characters"signup_form.username.$error.maxlength"Your username cannot be longer than 20 characters"signup_form.username.$error.unique"That username is taken,please try another

在我们的最后一个字段,我们使用我们之前编写的自定义验证。这个自定义验证使用的AngularJS指令:

app.directive();
        });
      });
    }
  }
}]);

当表单输入是有效的时,它将发送POST api/check/username请求到服务器来检查用户名是否可用。现在,很明显,因为我们在这里只谈论前端代码,我们没有为后端编写测试,尽管很容易。

更新:根据评论的意见,我已经加入了服务器超时检查。要查看完整的源代码,请点击here

最后,我们加上提交按钮,我们可以使用ng-disabled指令来根据验证是否有效控制按钮的禁用和启用:

ng-disabled"signup_form.$invalid"

正如我们上面所说的,表单是否有效的属性$invalid给我们提供了便利。

更新 2:虽然立即验证是很棒的,它可以立即提醒用户,但是当他们正在输入很长的能通过验证的文字时,他们讲在输入中途看到错误提示。你可以更好的来处理这一点。当用户点击提交时,或者当他们将光标移开输入框之后。让我们来看看这2种方式。

点击提交后显示验证信息

要在用户试图提交表单时显示的验证,你可以通过在scope中设置一个'submitted'值,并检查该值来控制显示错误

例如,让我们来看看第一个例子,只有在点击提交表单时才显示错误。使用ng-show指令来控制显示,我们可以添加一个检查,看是否已点击提交按钮:


        
       "signup_form.name.$dirty && signup_form.name.$invalid && signup_form.submitted"
            Your name is required.
        
                Your name is required to be at least 3 characters
        
                Your name cannot be longer than 20 characters
        

现在,那个错误信息的div只将在signup_form.submittedtrue显示。我们可以这样实现这个signupForm方法

app.controller('signupController',68)">'$scope',128)">$scope) {
  $scope.submitted = ;
  $scope.signupForm = () {
    if ($scope.signup_form.$valid) {
      // Submit as normal
    } else {
      $scope.signup_form.submitted = true;
    }
  }
}]);

现在,当用户尝试提交表单并且同时有一个无效的元素时,你可以捕获它,并告诉他们错误的原因。

当时去焦点时验证错误

如果你想保留错误验证的实时性,那么可以在用户离开该输入框时显示错误信息。要做到这一点,我们可以添加一个指令,将添加一个新的变量。

我们使用ngFocus指令,它看起来像:

'ngFocus',[function() {
  var FOCUS_CLASS = "ng-focused";
   {
    restrict: 'A'false;
      element.bind('focus',0)">(evt) {
        element.addClass(FOCUS_CLASS);
        scope.$apply(function() {ctrl.$focused = true;});
      }).bind('blur',0)">(evt) {
        element.removeClass(FOCUS_CLASS);
        scope.$apply(;});
      });
    }
  }
}]);

要使用ngFocus,我们只需要简单加上这个指令到输入框元素上,像这样:

ng-class"{error: signup_form.name.$dirty && signup_form.name.$invalid}"required ng-focus 

加上ngFocus指令后,将在输入框的blur和focus事件中注册相应操作,当焦点在该输入框时,它添加一个class(ng-focused),并且该输入框的$focused属性也将变为true。因此,你可以根据需求是否在焦点上来个性化设置显示错误消息。例如:

"signup_form.name.$dirty && signup_form.name.$invalid && !signup_form.name.$focused"

我希望这篇文章可以告诉你如何的很酷的使用AngularJS来进行表单验证。

原文:Form validation with AngularJS(en)

注:原文有一些demo可供测试,若有需要请查看原文。

猜你在找的Angularjs相关文章