Ajax异步交互 - 学习笔记(1)

效果图展示:

异步(Asynchronous)的概念和同步(Synchronous)相对。当一个异步过程调用发出后,调用者不需要立刻得到结果,可以继续做自己的事情,等到过程调用完毕,再通过回调函数通知调用方。而同步情况下,调用方必须等待对方得到结果,才能继续运行

具体解释参考http://www.w3school.com.cn/ajax/

 

前台代码

<%@ page language="java" import="java.util.*" pageEncoding="gbk"%>
 
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
  <meta http-equiv="content-type" content="text/html; charset=gbk">
    <title>welcome ,注册本系统</title>
 <link rel="stylesheet" type="text/css" href="style/style.css">
  <script type="text/javascript">
   var xhr=null;
   
  function checkUname(){
  var username=document.myform.uname.value;
  //alert(username);
  if(username==""||username==null){
    document.getElementById("msgDiv").innerHTML="<font color='red'>请输入用户名</font>";
  }
  //ajax的核心对象
  //var xhr=new XMLHttpRequest();//只对非ie浏览器生效
  if(window.ActiveXObject){
    xhr=new ActiveXObject("Microsoft.XMLHTTP");
  }else{
     xhr=new XMLHttpRequest();
  }
  var url="http://localhost:8080/12softsms0415/RegServlet?uname="+username;
   //当核心对象的状态发生改变,它的处理函数
  xhr.onreadystatechange=haolejiaowo;
  xhr.open("get",url,true);
  xhr.send(null);
  }
 
  //才是核心处理函数
  function haolejiaowo(){
 if(xhr.readyState==4&&xhr.status==200){
   var result=xhr.responseText;//得到远程服务器返回的结果
   if(result.indexOf("true")!=-1){
   alert(result);
     document.getElementById("msgDiv").innerHTML="<font color='red'>用户名已存在</font>";;
   }else{
     document.getElementById("msgDiv").innerHTML="可以注册";
   }
 }
  }
  </script>
  </head>

<body>
  <div align="center">
   <%--  登录  --%>
    <div class="login" align="center">
     <br/>
        <h2>短信系统注册</h2>
     <form action="UserServlet" method="post" name="myform">
       <input type="hidden" name="cmd" value="reg">
      用户名<input type="text" name="uname" class="input" οnblur="checkUname()"/>
      <div id="msgDiv" style="display:inline">提示信息</div>
      <br/>
      密&nbsp;&nbsp;码<input type="password" name="upass" class="input"/><br/>
      重复密码<input type="password" name="upassrep" class="input"/><br/>
      <input type="submit" value=" 注册 " class="btn"/>
     </form>
    </div>
  </div>
  </body>
</html>

 

 

Servlet核心代码

 public boolean isExist(String username){

    //模拟后台数据库有三个用户
  String[] names={"jack","rose","marry","12210810235"};
  for (String s : names) {
   if(username.equalsIgnoreCase(s)){
    return true;
   }
  }
  return false;
 }

doGet()方法


 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章