zoukankan      html  css  js  c++  java
  • angular编写表单验证

    angular编写表单验证#

    一、整体概述

    表单内容如下图,包括常用的用户名、密码、确认密码、手机、邮箱等

    1. 整体js代码很少,就一个指令用于写确认密码和密码是否相等。其他 验证都是使用angular自带的指令进行校验和显示。
    2. 本demo还使用了bootstrap的栅栏功能进行布局,因为想写的是demo所以很多样式以及其他限制就不写了,我认为越是简单越好让别人改写使用

    二、重点说明

    1、表单属性:

    $dirty:已经修改过

    $invalid:不合法

    $valid:合法

    $error:错误

    $pristine:未修改过

    novalidate 阻止表单默认操作


    <span class="col-4" ng-show="myForm.password.$dirty && myForm.password.$invalid">
        <small class="text-danger" ng-show="myForm.password.$error.required">
            密码是必填的
        </small>
        <small class="text-danger" ng-show="myForm.password.$error.minlength">
            长度不能小于8位
        </small>
        <small class="text-danger" ng-show="myForm.password.$error.maxlength">
            长度不能大于64位
        </small>
    </span>
    

    **2、相关指令:**

    ng-minlength:最小长度

    ng-maxlength:最大长度

    required:必填

    ng-pattern:正则表达式验证

    ng-disabled:按钮禁用


    <input type="text" class="col-6" name="phone" ng-model="phone" ng-pattern="/(^0d{2,3}-d{7,8}$)|(^1[3|4|5|6|7|8][0-9]{9}$)/" required/>
    

    <button ng-disabled="myForm.$invalid" ng-click="submit()">submit</button>
    

    **3、form表单一定要有name属性,每个input值也需要有name属性,比如已经输入过的表单表示是:myForm.name.$dirty 即 表单name.输入name.表单属性**

    4、确认密码自定义指令

    确认密码这个暂时无法通过原有的指令实现,所以使用了directive,主要是通过观察两个输入框的值,如果不相等则在确认密码栏后显示错误信息,如下


    var app = angular.module('app',[]);
    app.directive('compare',function(){
        return {
            require: 'ngModel',
            link: function(scope,ele,attrs,ctrl){
                var flag = false;
                scope.$watch("password",function(scope,ele,attrs,ctrl){
                    var password2 = attrs.myForm.password2.$viewValue;
                    if(scope != password2) {
                        flag = true;
                    }else{
                        flag = false;
                    }
                    attrs.myForm.password2.$invalid = flag;
                })
                scope.$watch("password2",function(scope,ele,attrs,ctrl){
                    var password = attrs.myForm.password.$viewValue;
                    if(scope != password) {
                        flag = true;
                    }else{
                        flag = false;
                    }
                    attrs.myForm.password2.$invalid = flag;
                })
            }
        }
    })
    
    源代码见github:`https://github.com/liaoanran/angular-formValidation`
  • 相关阅读:
    Windows抓屏技术
    几种常见的跨域技术
    实现圆角的3种方式
    svg基础
    nodejs基础(二)
    nodejs的基础(1)
    css3一些常见样式的兼容性处理
    JS中Array的使用
    浏览器的几种模式
    XHR2通信基础
  • 原文地址:https://www.cnblogs.com/liaoanran/p/8556850.html
Copyright © 2011-2022 走看看