zoukankan      html  css  js  c++  java
  • 利用jquery.validate异步验证用户名是否存在

    经过上百次的试验试和搜索,终于把jquery.validate的各种功能用法了解清楚,网上关于jquery.validate的AJAX表单验证比较少,特别是对rules里面的remote提得比较简单,使得学习起来比较难,下面发布一下我个人的用法:

    HTML头部引用:

    <script type="text/javascript" src="../js/jquery-1.3.2.min.js"></script>
    <script type="text/javascript" src="../js/jquery.validate.min.js"></script>
    <script type="text/javascript" src="../js/messages_cn.js"></script>

    HTML内容(部分):

    <form name="form1" id="form1" method="post" action="">
    <dl>
      <dt>用户名:</dt>
      <dd><input name="txtUserName" id="txtUserName" type="text" class="input1" /></dd>
    </dl>
    </form>

    JS代码部分:

    $(function() {
    //表单验证JS
        $("#form1").validate({
            //出错时添加的标签
            errorElement: "span",
            rules: {
                txtUserName: {
                    required: true,
                    minlength: 3,
                    maxlength: 16,
                    remote: {
                        type: "post",
                        url: "/tools/ValidateUserName.ashx",
                        data: {
                            username: function() {
                                return $("#txtUserName").val();
                            }
                        },
                        dataType: "html",
                        dataFilter: function(data, type) {
                            if (data == "true")
                                return true;
                            else
                                return false;
                        }
                    }
                }
            },
            success: function(label) {
                //正确时的样式
                label.text(" ").addClass("success");
            },
            messages: {
                txtUserName: {
                    required: "请输入用户名,3-16个字符(字母、数字、下划线),注册后不能更改",
                    minlength: "用户名长度不能小于3个字符",
                    maxlength: "用户名长度不能大于16个字符",
                    remote: "用户名不可用"
                }
            }

        });
    });

    应注意的地方:

    data: {
       username: function() {
       return $("#txtUserName").val();
    }
    有返回值,如果直接写“data: {username: $("#txtUserName").val();}”,这样是获取不到值的。



    已有 0 人发表留言,猛击->>这里<<-参与讨论


    ITeye推荐



  • 相关阅读:
    「BZOJ1935」[SHOI2007]园丁的烦恼
    【BZOJ3262】陌上花开
    CDQ分治入门
    「luogu2664」树上游戏
    zoj3995 fail树
    zoj3997网络流+数学
    树状数组区间更新区间查询以及gcd的logn性质
    可修改的区间第K大 BZOJ1901 ZOJ2112
    数论容斥比较快速的做法和二分图判定1
    浙工大新生赛莫队处理+区间DP+KMP+分析题
  • 原文地址:https://www.cnblogs.com/Jaylong/p/Jquery.html
Copyright © 2011-2022 走看看