使用ajax验证用户名重复

  继上次的用户注册登录案例之后,对其中的部分功能再做进一步改进。上一版中用户提交表单后才对用户名进行校验,虽然做了回显,但还是感觉功能弱了些。为了能有更好用户体验,不是在用户提交表单后才给提示,而是在用户输入用户名后就立即对该用户名进行数据库校验,经过晚上的测试现在可以使用纯js版和jquery版。
  准备工作,先编写好验证用户名重复的后台Servlet程序,然后在jsp或html中使用js对用户名进行验证,当用户输入用户名文本框推动焦点时立即触发验证。
下面是jquery代码。

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
    String path = request.getContextPath();
    String basePath = request.getScheme() + "://"
            + request.getServerName() + ":" + request.getServerPort()
            + path + "/";
%>

<% out.clear(); %><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>使用ajax进行异步验证</title>
    <meta http-equiv="content-type" content="text/html;charset=utf-8" />
    <style type="text/css">
        body{ font-size:12px;}
        table{ font-size:12px;}
        table input{ width:120px;}
        table em{ color:#ff0000;}
        #body{ margin-left:200px; margin-top:220px;}
    </style>
    <script type="text/javascript" src="Jquery/jquery-1.7.2.min.js"></script>
    <script language="javascript" type="text/javascript">
        $(document).ready(function(){
            $("#username").focus();
        });
        var hadoop = function(){
            // 异步验证用户是否重复
            if($.trim($("#username").val())==""){
                $("#message").html("用户名不能为空");
                $("#username").focus();
            }else{
                $.ajax({
                    type: "post",
                    url: "dumplicate.do",
                    data: "username=" + $("#username").val(),
                    success: function(message){
                        $("#message").html(message);
                    }
                });
            }
        };
    </script>
  </head>
  <body>
      <div id="body">
        <form action="#" method="post">
            <table>
                <tr>
                    <td>用户名:</td><td><input type="text" id="username" name="username" onblur="hadoop()" />
                    </td>
                    <td>
                        <em id="message"></em>
                    </td>
                </tr>
                <tr>
                    <td>密码:</td><td colspan="2"><input type="text" /></td>
                </tr>
            </table>
        </form>
    </div>
  </body>
</html>

下面是js版代码。

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
    String path = request.getContextPath();
    String basePath = request.getScheme() + "://"
            + request.getServerName() + ":" + request.getServerPort()
            + path + "/";
%>

<% out.clear(); %><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>使用ajax进行异步验证</title>
    <meta http-equiv="content-type" content="text/xml;charset=utf-8" />
    <style type="text/css">
        body{ font-size:12px;}
        table{ font-size:12px;}
        table input{ width:120px;font-size:12px;}
        table em{ color:#ff0000;}
        .tips{ text-align:right;}
        #body{ margin-left:200px; margin-top:220px;}
    </style>
    <script language="javascript" type="text/javascript">
        window.onload=function(){
            document.getElementById("username").focus();
        };
        var xmlhttp;
        function hadoop() {
            // 1.创建XMLHttpRequest对象  
            if (window.XMLHttpRequest) {
                // IE7,IE8,FireFox,Mozilla,Safari,Opera  
                xmlhttp = new XMLHttpRequest();
                if (xmlhttp.overrideMimeType) {
                    xmlhttp.overrideMimeType("text/xml");
                }
            } else if (window.ActiveXObject) {
                // IE6,IE5.5,IE5  
                var activexName = [ "MSXML2.XMLHTTP", "Miscrosoft.XMLHTTP" ];
                for ( var i = 0; i < activexName.length; i++) {
                    try {
                        xmlhttp = new ActiveXObject(activexName[i]);
                        break;
                    } catch (e) {
                    }
                }
            }
            if (xmlhttp == undefined || xmlhttp == null) {
                alert('当前浏览器不支持创建XMLHttpRequest对象');
                return;
            }
    
            //2.注册回调函数
            xmlhttp.onreadystatechange = callback;
            // 注意方法调用后面不加括号
            //xmlhttp.onreadystatechange = callback();  
    
            // 获取文本框中输入的内容,经过两次编码防止中文乱码
            // 后台使用URLDecoder.decode(username,"utf-8")对username解码 
            var userName = document.getElementById("username").value;
            if(userName==""){
                document.getElementById("message").innerHTML="用户名不能为空";
                $("#username").focus();
                return;
            }
            userName = encodeURI(encodeURI(userName));
            // 3.设置和服务器端交互参数  
            xmlhttp.open("POST", "${pageContext.request.contextPath }/dumplicate.do?username=" + userName, true);
    
            // 4.设置向服务器端发送的数据,启动和服务器端的交互  
            xmlhttp.send(null);
        }
    
        function callback() {
            // 5 .判断和服务器端的交互是否完成,还要判断服务器端是否正确返回了数据  
            if (xmlhttp.readyState == 4) {
                // 表示和服务器端的交互已经完成  
                if (xmlhttp.status == 200) {
                    // 表示服务器的响应代码是200,正确的返回了数据  
                    // 纯文本数据的接受方法  
                    var message = xmlhttp.responseText;
                    // XML数据对应的DOM对象的接受方法  
                    // 使用的前提是,服务器端需要设置content-type为text/xml  
                    // var domXml = xmlhttp.responseXML;  
    
                    //向div标签中填充文本内容的方法  
                    var div = document.getElementById("message");
                    if(message=="用户名已被注册"){
                        document.getElementById("username").focus();
                        document.getElementById("username").select();
                    }
                    div.innerHTML = message;
                }
            }
        }
    </script>
  </head>
  <body>
      <div id="body">
        <form action="#" method="post">
            <table>
                <tr>
                    <td class="tips">用户名:</td>
                    <td>
                        <input type="text" id="username" name="username" value="祁连山" onblur="hadoop()" />
                    </td>
                    <td>
                        <em id="message">*</em>
                    </td>
                </tr>
                <tr>
                    <td class="tips">密码:</td><td colspan="2"><input type="text" /></td>
                </tr>
            </table>
        </form>
    </div>
  </body>
</html>

  从上面的代码量就可以看出来jquery的强大之处了,所以有空没空多看看jquery,自己会用才是王道。在这里也感谢一位网名叫牛腩的广西南宁朋友提供js版本,jquery版本出自jquery文档,看来还是得多看文档哪。

原文地址:https://www.cnblogs.com/magics/p/3728758.html