【JS】JavaScript进行表单验证经常使用的判断条件

一、前言

      提交表单的时候有很多的条件需要判断,我们可以通过JS在html页面或者是jsp页面进行验证,下面小编就列出来常用的一些js验证使用的js代码,可以把他们抽取出来到一个js文件中,各个页面可以引用这个文件,使用这些方法。

二、js验证代码

  • 是否为空校验
//是否为空校验
function isEmpty(s) {
    var lll=trim(s);
    if( lll == null || lll.length == 0 )
        return true;
    else
        return false;
}
  • 删除字符串左边的空格

//删除字符串左边的空格
function ltrim(str) { 
    if(str.length==0)
        return(str);
    else {
        var idx=0;
        while(str.charAt(idx).search(/\s/)==0)
            idx++;
        return(str.substr(idx));
    }
}
  • 删除字符串右边的空格
//删除字符串右边的空格
function rtrim(str) { 
    if(str.length==0)
        return(str);
    else {
        var idx=str.length-1;
        while(str.charAt(idx).search(/\s/)==0)
            idx--;
        return(str.substring(0,idx+1));
    }
}
  • 删除字符串左右两边的空格
//删除字符串左右两边的空格
function trim(str) { 
    return(rtrim(ltrim(str)));
}
  • 日期相比较

/*日期相比较*/
function compareDate(date1, date2) {
    if (trim(date1) == trim(date2))     
        return 0;
    if (trim(date1) > trim(date2))      
        return 1;
    if (trim(date1) < trim(date2))      
        return -1;
}
  • 校验是否是Email
//校验是否是Email
function isEmail(eml) {
    if(trim(eml)!='') {
      var re=new RegExp("@[\\w]+(\\.[\\w]+)+$");
      return(re.test(eml));
    }
    else
      return(true);
}
  • 是否是电话号
//是否是电话号
function isTel(tel) {
    var charcode;
    for (var i=0; i<tel.length; i++)    
    {
        charcode = tel.charCodeAt(i);
        if (charcode < 48 && charcode != 45 || charcode > 57)   
            return false;
    }
    return true;
}
  • 校验是否是实数

//校验是否是实数
function isnumber(num) {
    var re=new RegExp("^-?[\\d]*\\.?[\\d]*$");
    if(re.test(num))
        return(!isNaN(parseFloat(num)));
    else
        return(false);
}
  • 校验是否是整数
//校验是否是整数
function isinteger(num) {
    var re=new RegExp("^-?[\\d]*$");
    if(re.test(num))
        return(!isNaN(parseInt(num)));
    else
        return(false);
}

三、举例

这是一个示例的表单,提交要求如下:

  • 用户代码不为空,至少四位,首字符为字母

  • 用户名不为空

  • 密码至少6位

  • 联系电话不为空,进行判断,规则:都为数字

  • email,条件:包含@,@不出现在最前面,也不出现在最后面

这里写图片描述

实现代码:

function addUser() {
        var userIdField = document.getElementById("userId");
        //用户代码不能为空
        if (trim(userIdField.value) == "" ) {
            alert("用户代码不能为空!");
            userIdField.focus();
            return;
        }
        //用户代码至少四个字符
        if (trim(userIdField.value).length < 4) {
            alert("用户代码至少4个字符!");
            userIdField.focus();
            return;
        }

        //第一个字符必须是字母
        if (!(trim(userIdField.value).charAt(0) >='a' && trim(userIdField.value).charAt(0) <='z')) {
            alert("用户代码首字符必须为字母!");
            userIdField.focus();
            return;
        }

        //判断用户代码只能是数字或字母,为4~6位
        /*
        if (!(trim(userIdField.value).length >=4 && trim(userIdField.value).length <=6)) {
            alert("用户代码只能为4~6位!!");
            userIdField.focus();
            return;
        }
        for (var i=0; i<trim(userIdField.value).length; i++) {
            var c = trim(userIdField.value).charAt(i);
            if (!((c >= '0' && c <='9') || (c >='a' && c <='z') || (c >='A' && c <='Z'))) {
                alert("用户代码必须为数字和字母!");
                userIdField.focus();
                return;
            }
        }
        */

        //采用正则表达式判断用户代码只能是数字或字母,为4~6位(中午作业)
        var re = new RegExp("/^[a-zA-Z0-9]{4,6}$/");
        if (!re.test(trim(userIdField.value))) {
            alert("用户代码必须为数字或字母,只能为4~6位!");
            userIdField.focus();
            return;
        }


        //用户名称必须输入,不能和用户代码不能为空一致(中午作业)
        if (trim(document.getElementById("userName").value).length == 0) {
            alert("用户名称不能为空!");
            document.getElementById("userName").focus();
            return;
        }

        //密码至少6位(中午作业)
        if (trim(document.getElementById("password").value).length < 6) {
            alert("密码至少6位!");
            document.getElementById("password").focus();
            return;
        }
        //如果联系电话不为空,进行判断,判断规则:都为数字,采用两种方式:1、采用正则,2、不采用正则(中午作业)
        var contactTelField = document.getElementById("contactTel");
        //alert("a" + trim(contactTelField.value) + "a");
        //不采用正则
        /*
        if (trim(contactTelField.value) != "") {

            for (var i=0; i<trim(contactTelField.value).length; i++) {
                var c = trim(contactTelField.value).charAt(i);
                if (!(c >= '0' && c <= '9')) {
                    alert("电话号码不合法!");
                    contactTelField.focus();
                    return;
                }
            }
        }
        */
        if (trim(contactTelField.value) != "") { 
            //采用正则
            re.compile(/^[0-9]*$/);
            if (!re.test(trim(contactTelField.value))) {
                alert("电话号码不合法!");
                contactTelField.focus();
                return;
            }   
        }

        //如果emial不能空,进行判断,判断规则:只要包含@即可,@最好不再最前面和最后面
        var emailField = document.getElementById("email");
        if (trim(emailField.value).length != 0) {
            var emailValue = trim(emailField.value);
            if ((emailValue.indexOf("@") == 0) || (emailValue.indexOf("@") == (emailValue.length - 1))) {
                alert("email地址不正确!");
                emailField.focus();
                return;             
            }
            if (emailValue.indexOf("@") < 0) {
                alert("email地址不正确!");
                emailField.focus();
                return;             
            }
        }

        /*
        document.getElementById("userForm").action="user_add.jsp";
        document.getElementById("userForm").method="post";
        document.getElementById("userForm").submit();
        */

        //等同上面的写法
        with (document.getElementById("userForm")) {
            action="user_add.jsp";
            method="post";
            submit();
        }
    }

注意:在使用正则表达式的时候需要提前创建正则表达式对象,比如var re = new RegExp(“/^[a-zA-Z0-9]{4,6}$/”);

四、小结

      代码库!这是大家的代码库!

      以后做web项目必不可少的验证,这些是js的基础,使用了DOM来进行数据的获取验证,使用了BOM进行数据向后台的传输,总之大家还是要对这里的知识比较熟悉,熟悉一下服务器控件和html控件的传输数据区别。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 13
    评论
 两个日期比较  /* 用途:检查开始日期是否小于等于结束日期 输入: s:字符串 开始日期 格式:2001-5-4 e:字符串 结束日期 格式:2002-5-4 返回: 如果通过开始日期小于等于结束日期返回true,否则返回false */ function data_compare(s,e) {  var arr=s.split("-");  var starttime=new Date(arr[0],arr[1],arr[2]);... 更多 两个日期比较 信息  为空或全是空格  /* 用途:检查输入字符串是否为空或者全部都是空格 输入:str 返回: 如果全是空返回true,否则返回false */ function isNull(str) { if (str == "") return true; var regu = "^[ ]+$"; ..... 更多 为空或全是空格 信息  判断是否是日期  /* 用途:判断是否是日期 输入:date:日期;匹配的格式: 2010-5-16 返回:如果通过验证返回true,否则返回false */ function isDate(str){ if (isNull(str)) return false;  var r = str.match(/^(\d{4})(-|\/)(\d{1,2})(-|\/)(\d{1,2})$/);  if(r==null)return false;  var d= new Date(r[1], r[3]-1, r[5]); ... 更多 判断是否是日期 信息  字母数字下划线  /* 用途:检查输入字符串是否只由英文字母和数字和下划线组成 输入: s:字符串 返回: 如果通过验证返回true,否则返回false */ function isNumberOr_Letter(s) {//判断是否是数字或字母 var regu = "^[0-9a-zA-Z\_]+$"; var re = new RegExp(regu); if (re.test(s))... 更多 字母数字下划线 信息  字符1以字符串2开始  /* 用途:字符1是否以字符串2开始 输入:str1:字符串;str2:被包含的字符串 返回:如果通过验证返回true,否则返回false */ function isFirstMatch(str1, str2) { var index = str1.indexOf(str2); if (index == 0) return true; return false; } 更多 字符1以字符串2开始 信息  字符1以字符串2结束  /* 用途:字符1是否以字符串2结束 输入:str1:字符串;str2:被包含的字符串 返回:如果通过验证返回true,否则返回false */ function isLastMatch(str1, str2) { var index = str1.lastIndexOf(str2); if (str1.length == index + str2.length) return true; return false; } 更多 字符1以字符串2结束 信息  字符1包含字符串2  /* 用途:字符1是包含字符串2 输入:str1:字符串;str2:被包含的字符串 返回:如果通过验证返回true,否则返回false */ function isMatch(str1, str2) { var index = str1.indexOf(str2); if (index == -1) return false; return true; } 更多 字符1包含字符串2 信息  是否为email  /* 用途:检查输入对象的值是否符合E-Mail格式 输入:str 输入的字符串 返回:如果通过验证返回true,否则返回false */ function isEmail(str) { var myReg = /^[-_A-Za-z0-9]+@([_A-Za-z0-9]+\.)+[A-Za-z0-9]{2,3}$/; if (myReg.test(str)) return true; return false; } 更多 是否为email 信息  是否为手机号码  /* 用途:检查输入手机号码是否正确 输入: s:字符串 返回: 如果通过验证返回true,否则返回false */ function checkMobile(s) { var regu = /^[1][0-9][0-9]{9}$/; var re = new RegExp(regu); if (re.test(s)) .... 更多 是否为手机号码 信息  是否为数字  /* 用途:检查输入字符串是否是数字 输入: str:字符串 返回: 如果通过验证返回true,否则返回false */ function isNumber(str)  {              var reg = /^\d+$/;     if (reg.test(str))... 更多 是否为数字 信息  是否为时间  /* 用途:检查输入字符串是否符合时间格式 输入: time:字符串 返回: 如果通过验证返回true,否则返回false */ function isTime(time){  var regex = /^[0-2]{1}[0-9]{1}:[0-5]{1}[0-9]{1}:[0-5]{1}[0-9]{1}$/;  if(!regex.test(time)){    return false;  } .... 更多 是否为时间 信息  是否为正整数  /* 用途:检查输入字符串是否符合正整数格式 输入: s:字符串 返回: 如果通过验证返回true,否则返回false */ function isNumber(s) { var regu = "^[0-9]+$"; var re = new RegExp(regu); if (s.search(re) != -1) ... 更多 是否为正整数 信息  是否为电话号码  /* 用途:检查输入字符串是否符合国内固话或者传真格式 输入: s:字符串  格式例如:020-87110252 返回: 如果通过验证返回true,否则返回false */ function isTel(s){   var reg=/^((0\d{2,3})-)?(\d{7,8})(-(\d{3,}))?$/;   if(!reg.test(s))... 更多 是否为电话号码 信息  是否为端口号  /* 用途:检查输入对象的值是否符合端口号格式 输入:str 输入的字符串 返回:如果通过验证返回true,否则返回false */ function isPort(str) { return (isNumber(str) && str < 65536); } 更多 是否为端口号 信息

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

你个佬六

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值