手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >AngularJs验证重复密码的方法(两种)
AngularJs验证重复密码的方法(两种)
摘要:本文给大家分享angularjs验证重复密码的两种方法。具体方法详情如下所示:第一种:密码重复密码两次密码不一致/*JS*/app.cont...

本文给大家分享angularjs验证重复密码的两种方法。具体方法详情如下所示:

第一种:

<label for="password">密码</label> <input id="password" name="password" type="password" ng-model="user.password" required> <label for="repassword">重复密码</label> <input id="repassword" name="repassword" type="password" ng-model="repassword" required> <span ng-show="user.password!=repassword">两次密码不一致</span> <input type="submit" value="SAVE" ng-disabled="submit(userForm)"/> /*JS*/ app.controller("main",function($scope){ $scope.submit=function(ngFormController){ return ngFormController.$invalid; /*valid的取反*/ }; });

这种是单纯的判断两个ng-model所在的值是否相等,不等则显示出被ng-show指令控制的信息,等则隐藏。

但这种办法虽然很简单,但是却有个我认为比较严重的缺陷:这个“密码不一致”并没有影响到ngFormController的内部。也就是说,即使它两次密码不正确,最后的提交按钮还是可以点击的,因为ngFormController的$invalid 并没有认为两次密码不正确是一种错误。

参考一下AngularJS的指令ng-maxlength等,他们却可以引起$invalid 的检测,所以要解决上面的问题,我觉得办法之一就是创建一个用于验证两次密码是否一致的自定义指令。

/*指令创建*/ app.directive('equals',function(){ return{ require:'ngModel', link:function(scope,elm,attrs,ngModelCtrl){ function validateEqual(myValue){ var valid = (myValue === scope.$eval(attrs.equals)); ngModelCtrl.$setValidity('equal',valid); return valid ? myValue : undefined; } ngModelCtrl.$parsers.push(validateEqual); ngModelCtrl.$formatters.push(validateEqual); scope.$watch(attrs.equals,function(){ ngModelCtrl.$setViewValue(ngModelCtrl.$viewValue); }) } } }); <> <label for="password">密码</label> <input id="password" name="password" type="password" ng-model="user.password" required> <label for="repassword">重复密码</label> <input id="repassword" name="repassword" type="password" ng-model="repassword" <>equals="user.password" required> <span ng-show="user.password!=repassword">两次密码不一致</span> <input type="submit" value="SAVE" ng-disabled="submit(userForm)"/>

这样,加上第一个办法的判断,就可以完美地验证重复密码了。

以上所述是小编给大家介绍的AngularJs验证重复密码的方法,希望对大家有所帮助,如果大家有任何疑问请给我们留言,小编会及时回复大家的。在此也非常感谢大家对查字典教程网的支持!

【AngularJs验证重复密码的方法(两种)】相关文章:

JavaScript判断数组是否包含指定元素的方法

创建你的第一个AngularJS应用的方法

AngularJs中route的使用方法和配置

js去字符串前后空格的实现方法

js去除浏览器默认底图的方法

JS验证IP,子网掩码,网关和MAC的方法

JavaScript中的blink()方法的使用

jQuery获得字体颜色16位码的方法

javascript验证邮件地址和MX记录的方法

js生成验证码并直接在前端判断

精品推荐
分类导航