重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章将为大家详细讲解有关怎么在Angularjs中使用指令实现表单校验,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
公司主营业务:成都做网站、网站建设、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。成都创新互联是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。成都创新互联推出齐河免费做网站回馈大家。
如下为一个简易表单,有四项提示信息,依据状态呈现。校验规则为数字,大写字母,小写字母至少出现两项,通过正则配合ng-pattern
能够实现相同的效果,此处仅为引入指令校验,不做深究。其中,user-validator
为自定义指令。
校验指令
校验指令代码如下:
angular.module('shuffleApp', []) .directive('userValidator', ['$log', function($log) { return { restrict: 'A', require: 'ngModel', link: function($scope, $element, $attrs, $ngModelCtrl) { var verifyRule = [/^\d+$/, /^[a-z]+$/, /^[A-Z]+$/]; var verify = function(input) { return !(verifyRule[0].test(input) || verifyRule[1].test(input) || verifyRule[2].test(input)); }; $ngModelCtrl.$parsers.push(function(input) { var validity = verify(input); $ngModelCtrl.$setValidity('defined', validity); return validity ? input : false; }); $ngModelCtrl.$formatters.push(function(input) { var validity = verify(input); $ngModelCtrl.$setValidity('defined', validity); return validity ? input : false; }) } } }]);
指令内容非常简单,检测是否全为数字,小写字母,大写字母,然后取反即得到校验结果。然后在$parser, $formatter内部设置校验结果即可。
关于怎么在Angularjs中使用指令实现表单校验就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。