AJAX(Asynchronous JAvaScript and XML)实现异步刷新

通过AJAX Asynchronous JAvaScript and XML 实现异步刷新

  • 用于用户名校验的页面

    准备一个JSP页面,叫做checkName.jsp用于校验提交的用户名是否存在 
    如果提交的用户名是abc就打印存在,否则就可以使用 
    <%@ page language="java" contentType="text/html; charset=UTF-8"
        pageEncoding="UTF-8" isELIgnored="false"%>
     
    <%
        String name = request.getParameter("name");
         
        if("abc".equals(name))
            out.print("<font color='red'>已经存在</font>");
        else
            out.print("<font color='green'>可以使用</font>");
         
    %>
    
  • 不使用AJAX 通过刷新页面验证账号是否存在

    如果不使用AJAX,传统的方法需要通过提交数据 刷新页面来获知用户名是否存在。
    <form action="http://how2j.cn/study/checkName.jsp">
     
    输入账号 <input name="name" type="text" value="abc">
     
    <input type="submit" value="验证账号是否存在">
     
    </form>
  • 使用AJAX 通过无刷新验证账号是否存在
    <span>输入账号 :</span>
    <input id="name" name="name" οnkeyup="check()" type="text"> 
    <span id="checkResult"></span>
     
    <script>
    var xmlhttp;
    function check(){
      var name = document.getElementById("name").value;
      var url = "http://how2j.cn/study/checkName.jsp?name="+name;
     
      xmlhttp =new XMLHttpRequest();
      xmlhttp.onreadystatechange=checkResult; //响应函数
      xmlhttp.open("GET",url,true);   //设置访问的页面
      xmlhttp.send(null);  //执行访问
    }
     
    function checkResult(){
      if (xmlhttp.readyState==4 && xmlhttp.status==200)
        document.getElementById('checkResult').innerHTML=xmlhttp.responseText;
      
    }
     
    </script>
  • AJAX 请求和相应图示
  • 创建XHR
    创建XHR对象 XMLHttpRequest
    XHR对象是一个javascript对象,它可以在用户没有感觉的情况下,就像背后运行的一根小线程一般,悄悄的和服务器进行数据交互
    AJAX就是通过它做到无刷新效果的
    <script>
    var xmlhttp =new XMLHttpRequest();
    document.write(xmlhttp);
    </script>
  • 设置响应函数
    XHR对象的作用是和服务器进行交互,所以既会发消息给服务器,也能接受服务器返回的响应。 
    当服务器响应回来的时候,调用怎么处理呢? 
    通过 xmlhttp.onreadystatechange=checkResult 就可以指定用checkResult 函数进行处理。

  • 设置并发出请求
    通过open函数设置背后的这个小线程,将要访问的页面url ,在本例中就是 checkName.jsp
    xmlhttp.open("GET",url,true);
    通过send函数进行实际的访问
    xmlhttp.send(null);

    null表示没有参数,因为参数已经通过“GET" 方式,放在url里了。
    只有在用"POST",并且需要发送参数的时候,才会使用到send。
    类似这样:
    xmlhttp.send("user="+username+"&password="+password)

  • 处理响应信息
    在checkResult 函数中处理响应
    function checkResult(){
      if (xmlhttp.readyState==4 && xmlhttp.status==200)  
         document.getElementById('checkResult').innerHTML=xmlhttp.responseText;
    }
    xmlhttp.readyState 4 表示请求已完成
    xmlhttp.status 200 表示响应成功
    xmlhttp.responseText; 用于获取服务端传回来的文本
    document.getElementById('checkResult').innerHTML 设置span的内容为服务端传递回来的文本
  • 再完整的演示一遍

    1. 创建XHR对象
    2. 设置响应函数
    3. 设置要访问的页面
    4. 发出请求
    5. 当服务端的响应返回,响应函数被调用。
    6. 在响应函数中,判断响应是否成功,如果成功获取服务端返回的文本,并显示在span中。

    <span>输入账号 :</span>
    <input id="name" name="name" οnkeyup="check()" type="text"> 
    <span id="checkResult"></span>
      
    <script>
    var xmlhttp;
    function check(){
      var name = document.getElementById("name").value;
      var url = "http://how2j.cn/study/checkName.jsp?name="+name;
      
      xmlhttp =new XMLHttpRequest();
      xmlhttp.onreadystatechange=checkResult; //响应函数
      xmlhttp.open("GET",url,true);   //设置访问的页面
      xmlhttp.send(null);  //执行访问
    }
      
    function checkResult(){
      if (xmlhttp.readyState==4 && xmlhttp.status==200)
        document.getElementById('checkResult').innerHTML=xmlhttp.responseText;
       
    }
      
    </script>
  • checkName.jsp

    <%@ page language="java" contentType="text/html; charset=UTF-8"
        pageEncoding="UTF-8" isELIgnored="false"%>
     
    <%
        String name = request.getParameter("name");
         
        if("abc".equals(name))
            out.print("<font color='red'>已经存在</font>");
        else
            out.print("<font color='green'>可以使用</font>");
         
    %>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值