• JQuery表单验证(validate):常用例子介绍


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

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

    1. <form id="signupForm" method="get" action="">
    2. <fieldset>
    3. <legend>Validating a complete form</legend>
    4. <p>
    5. <label for="firstname">Firstname</label>
    6. <input id="firstname" name="firstname" class="required" />
    7. </p>
    8. <p>
    9. <label for="lastname">Lastname</label>
    10. <input id="lastname" name="lastname" />
    11. </p>
    12. <p>
    13. <label for="username">Username</label>
    14. <input id="username" name="username" />
    15. </p>
    16. <p>
    17. <label for="password">Password</label>
    18. <input id="password" name="password" type="password" />
    19. </p>
    20. <p>
    21. <label for="confirm_password">Confirm password</label>
    22. <input id="confirm_password" name="confirm_password" type="password" />
    23. </p>
    24. <p>
    25. <label for="email">Email</label> <input id="email" name="email" />
    26. </p>
    27. <p>
    28. <input class="submit" type="submit" value="Submit" />
    29. </p>
    30. </fieldset>
    31. </form>

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

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

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

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

    1. <script>
    2. $(document).ready(function(){
    3. $("#signupForm").validate();
    4. }
    5. script>

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

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

    1. $(document).ready(function() {
    2. $("#signupForm").validate({
    3. rules : {
    4. firstname : "required",
    5. lastname : "required",
    6. username : "required",
    7. password : "required",
    8. confirm_password : {
    9. required : true,
    10. equalTo : "#password"
    11. },
    12. email : {
    13. required : true,
    14. email : true
    15. }
    16. }
    17. });
    18. })

    这样以来,也能达到相同的效果。
    那么,接下的问题,就是显示的错误提示是默认的。我们需要使用自定义的提示:

    1. $(document).ready(function() {
    2. $("#signupForm").validate({
    3. rules : {
    4. firstname : "required",
    5. lastname : "required",
    6. username : "required",
    7. password : "required",
    8. confirm_password : {
    9. required : true,
    10. equalTo : "#password"
    11. },
    12. email : {
    13. required : true,
    14. email : true
    15. }
    16. },
    17. messages : {
    18. firstname : "必填项",
    19. lastname : "必填项",
    20. username : "必填项",
    21. password : "必填项",
    22. confirm_password : {
    23. required : "必填项",
    24. equalTo : "密码不一致"
    25. },
    26. email : {
    27. required : "必填项",
    28. email : "格式有误"
    29. }
    30. }
    31. });
    32. });

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

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

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

    1. $(document).ready(function() {
    2. $("#signupForm").validate({
    3. rules : {
    4. firstname : "required",
    5. lastname : "required",
    6. username : "required",
    7. password : {
    8. required : true,
    9. minlength : 4,
    10. maxlength : 15
    11. },
    12. confirm_password : {
    13. required : true,
    14. equalTo : "#password"
    15. },
    16. email : {
    17. required : true,
    18. email : true
    19. }
    20. },
    21. messages : {
    22. firstname : "必填项",
    23. lastname : "必填项",
    24. username : "必填项",
    25. password : {
    26. required : "必填项",
    27. minlength : jQuery.format("密码长度不少于{0}位"),
    28. maxlength : jQuery.format("密码长度不超过{0}位")
    29. },
    30. confirm_password : {
    31. required : "必填项",
    32. equalTo : "密码不一致"
    33. },
    34. email : {
    35. required : "必填项",
    36. email : "格式有误"
    37. }
    38. }
    39. });
    40. });

    使用remote

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

    1. $(document).ready(function() {
    2. $("#signupForm").validate({
    3. event : "keyup" || "blur"
    4. })
    5. });

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

    1. $(document).ready(function() {
    2. $("#signupForm").validate({
    3. debug : true
    4. })
    5. });

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

    1. $(document).ready(function() {
    2. $("#signupForm").validate({
    3. SubmitHandler : function() {
    4. alert("success");
    5. }
    6. })
    7. });
  • 相关阅读:
    【C++基础】this指针
    OpenHarmony教程指南-自定义通知推送
    Go内存管理一文足矣
    Z检验|T检验|样本标准差S代替总体标准差 σ
    0088 堆排序
    详谈ORB-SLAM2的帧
    给大家分享一份适合练手的软件测试实战项目
    TDengine服务器端启动失败问题(客户端连接失败问题)
    greenhills multi ide for mips && ppc
    计算机专业的学生需要每天刷题吗?
  • 原文地址:https://blog.csdn.net/apple_51426592/article/details/127757630