jquery 表单验证之通过 class验证表单不为空

前端技术 2023/09/06 JavaScript

在开发系统时,往往都有某些表单数据为必填项,若用jQuery通过ID去验证,不仅会影响效率,还会有所遗漏,不易于后期维护。

本章将介绍如何利用jQuery,通过为表单配置class进行统一验证。(ID一个页面只可以使用一次;class可以多次引用)

1:为input添加class,名字可以随意设置,但每个input需要保持一致,本章案例calss设置为noNull。(若input已有class属性,可直接加到其后)

2:为input添加一个属性,用来后期通过jquery获取该字段,用作提示语。本章案例提示属性为notNull。

3:通过jQuery遍历页面中所有calss为noNull的表单,验证其是否为空,若为空,通过获取notNull的字段,进行为空提示。

具体如何设置,请参照下面的案例。本章针对input,radio,select,checkbox等类型都进行了阐述。

<!DOCTYPE html>
<html>
<head lang=\"en\">
  <meta charset=\"UTF-8\">
</head>
<body>
  <form>
      <!-- input -->
      <div>
        姓名: <input type=\"text\" name=\"name\" notNull=\"姓名\" class=\"form-control noNull\"> 
      </div>
      <br>
      <!-- radio -->
      <div>
       性别:
       男<input type=\"radio\" name=\"sex\" value=\"0\" class=\"noNull\" notNull=\"性别\">
       女<input type=\"radio\" name=\"sex\" value=\"1\" >
      </div>
      <br>
      <!-- select -->
      <div>
        年龄:
        <select name=\"age\" class=\"noNull\" notNull=\"年龄\">
          <option value =\"\">请选择</option>
          <option value =\"1\">1</option>
          <option value =\"2\">2</option>
        </select>
      </div>
      <br>
      <!-- checkbox -->
      <div>
        兴趣:
        打球<input type=\"checkbox\" name=\"hobby\" value=\"1\" class=\"noNull\" notNull=\"兴趣\">
        唱歌<input type=\"checkbox\" name=\"hobby\" value=\"2\">
        跳舞<input type=\"checkbox\" name=\"hobby\" value=\"3\">
      </div>
      <br>
     <button type=\"button\" class=\"btn-c\" onclick=\"bubmi()\">保存</button>
  </form>
<script src=\"jquery-1.9.1.min.js\"></script>
<script type=\"text/javascript\">
function bubmi(){
  $(\".noNull\").each(function(){
    var name = $(this).attr(\"name\");
    if($(this).val()==\"\"){
    alert($(this).attr(\'notNull\')+\"不能为空\");return false;
    }
    if($(this).attr(\"type\")==\"radio\"){ 
      if ($(\"input[name=\'\"+name+\"\']:checked\").size() < 1){ 
        alert($(this).attr(\'notNull\')+\"不能为空!\"); 
        return false; 
      } 
    }
    if($(this).attr(\"type\")==\"checkbox\"){ 
      if ($(\'input[name=\"\'+name+\'\"]:checked\').size() < 1){ 
        alert($(this).attr(\'notNull\')+\"不能为空!\"); 
        return false; 
      } 
    }    
  })  
}
</script>
</body>
</html>

下面给大家介绍jquery.validate.js验证插件

jquery.validate.js是jquery旗下的一个验证插件,借助jquery的优势,我们可以迅速验证一些常见的输入,并且可以自己扩充自己的验证方法。

举个例子,有这么一个表单:

<form id=\"signupForm\" method=\"get\" action=\"\">
<fieldset>
<legend>Validating a complete form</legend>
<p>
<label for=\"firstname\">Firstname</label>
<input id=\"firstname\" name=\"firstname\" class=\"required\"/>
</p>
<p>
<label for=\"lastname\">Lastname</label>
<input id=\"lastname\" name=\"lastname\" />
</p>
<p>
<label for=\"username\">Username</label>
<input id=\"username\" name=\"username\" />
</p>
<p>
<label for=\"password\">Password</label>
<input id=\"password\" name=\"password\" type=\"password\" />
</p>
<p>
<label for=\"confirm_password\">Confirm password</label>
<input id=\"confirm_password\" name=\"confirm_password\" type=\"password\" />
</p>
<p>
<label for=\"email\">Email</label>
<input id=\"email\" name=\"email\" />
</p>
<p>
<input class=\"submit\" type=\"submit\" value=\"Submit\"/>
</p>
</fieldset>
</form>

在这个表单中,有名、姓、用户名、密码、确认密码和email。他们都为非空,并且电子邮件需要是格式正确的地址、确认密码和密码一致。使用jQuery验证最简单的方式是引入jquery.js和jquery validation.js两个js文件。然后分别在input中加入class即:

<input id=\"firstname\" name=\"firstname\" class=\"required\"/>
<input id=\"lastname\" name=\"lastname\" class=\"required\"/>
<input id=\"username\" name=\"username\" class=\"required\"/>
<input id=\"password\" name=\"password\" type=\"password\" class=\"required\"/>
<input id=\"confirm_password\" name=\"confirm_password\" type=\"password\" class=\"required\" equalTo=\"#password\"/>
<input id=\"email\" name=\"email\" class=\"required email\"/>

以下列出validate自带的默认验证

required: \"必选字段\",
remote: \"请修正该字段\",
email: \"请输入正确格式的电子邮件\",
url: \"请输入合法的网址\",
date: \"请输入合法的日期\",
dateISO: \"请输入合法的日期 (ISO).\",
number: \"请输入合法的数字\",
digits: \"只能输入整数\",
creditcard: \"请输入合法的信用卡号\",
equalTo: \"请再次输入相同的值\",
accept: \"请输入拥有合法后缀名的字符串\",
maxlength: jQuery.format(\"请输入一个长度最多是 {0} 的字符串\"),
minlength: jQuery.format(\"请输入一个长度最少是 {0} 的字符串\"),
rangelength: jQuery.format(\"请输入一个长度介于 {0} 和 {1} 之间的字符串\"),
range: jQuery.format(\"请输入一个介于 {0} 和 {1} 之间的值\"),
max: jQuery.format(\"请输入一个最大为 {0} 的值\"),
min: jQuery.format(\"请输入一个最小为 {0} 的值\")

  然后,在document的read事件中,加入如下方法:

   <script>
    $(document).ready(function(){
        $(\"#signupForm\").validate();
    }
   </script>

这样,当form被提交的时候,就会根据input指定的class来进行验证了。如果失败,form的提交就会被阻止。并且,将提示信息显示在input的后面。

不过,这样感觉不好,因为验证规则侵入了我们的html代码。还有一个方式,便是使用“rules”。我们将input的那些验证用class删除掉。然后修改document的ready事件响应代码:

$(document).ready(function(){
$(\"#signupForm\").validate({
rules:{
firstname:\"required\",
lastname:\"required\",
username:\"required\",
password:\"required\",
confirm_password:{
required:true,
equalTo:\"#password\"
},
email:{
required:true,
email:true
}
}
});
})

这样以来,也能达到相同的效果。

    那么,接下的问题,就是显示的错误提示是默认的。我们需要使用自定义的提示:

$(document).ready(function(){
$(\"#signupForm\").validate({
rules:{
firstname:\"required\",
lastname:\"required\",
username:\"required\",
password:\"required\",
confirm_password:{
required:true,
equalTo:\"#password\"
},
email:{
required:true,
email:true
}
},
messages:{
firstname:\"必填项\",
lastname:\"必填项\",
username:\"必填项\",
password:\"必填项\",
confirm_password:{
required:\"必填项\",
equalTo:\"密码不一致\"
},
email:{
required:\"必填项\",
email:\"格式有误\"
}
}
});
})

如果你还想在错误信息上显示特别的样式(比如字体为红色)即可通过添加:

<style type=\"text/css\">
#signupForm label.error {
padding-left: 16px;
margin-left: 2px;
color:red;
background: url(img/unchecked.gif) no-repeat 0px 0px;
}
</style>

继续添加对输入密码长度的验证规则:

$(document).ready(function(){
$(\"#signupForm\").validate({
rules:{
firstname:\"required\",
lastname:\"required\",
username:\"required\",
password:{
required:true,
minlength:4,
maxlength:15
},
confirm_password:{
required:true,
equalTo:\"#password\"
},
email:{
required:true,
email:true
}
},
messages:{
firstname:\"必填项\",
lastname:\"必填项\",
username:\"必填项\",
password:{
required:\"必填项\",
minlength:jQuery.format(\"密码长度不少于{0}位\"),
maxlength:jQuery.format(\"密码长度不超过{0}位\")
},
confirm_password:{
required:\"必填项\",
equalTo:\"密码不一致\"
},
email:{
required:\"必填项\",
email:\"格式有误\"
}
}
});
})

使用remote

可以通过event指定触发效验方式(可选值有keyup(每次按键时),blur(当控件失去焦点时),不指定时就只在按提交按钮时触发)

$(document).ready(function(){
$(\"#signupForm\").validate({
event:\"keyup\" || \"blur\"
})
})

如果通过指定debug为true则表单不会提交只能用来验证(默认为提交),可用来调试

$(document).ready(function(){
$(\"#signupForm\").validate({
debug:true
})
})

如果在提交前还需要进行一些自定义处理使用submitHandler参数

$(document).ready(function(){
$(\"#signupForm\").validate({
SubmitHandler:function(){
alert(\"success\");
}
})
})

本文地址:https://www.stayed.cn/item/17445

转载请注明出处。

本站部分内容来源于网络,如侵犯到您的权益,请 联系我

我的博客

人生若只如初见,何事秋风悲画扇。