• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    AJAX和JSP混合使用方法实例

    首先要知道AJAX 是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。

    什么是 AJAX ?

    AJAX = 异步 JavaScript 和 XML。

    AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术。AJAX 是一种用于创建快速动态网页的技术。

    通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。

    传统的网页(不使用 AJAX)如果需要更新内容,必需重载整个网页面。

    AJAX工作原理


    AJAX请求

    ajax请求是依靠XMLHttpRequest对象,因此在请求前先要创建其对象

    var xmlhttp;
    //兼容性写法创建请求实例,IE5 6支持else里面的方法
    if (window.XMLHttpRequest){
    xmlhttp = new XMLHttpRequest();
    }else {
    xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
    }

    接着向服务器发送请求

    open函数有三个参数,请求方式,请求地址,请求是异步还是同步
    send(String)函数有一个参数,只有当请求方式为post的时候,String参数才需要带上

    那么GET和POST的区别呢?

    与 POST 相比,GET 更简单也更快,并且在大部分情况下都能用。

    然而,在以下情况中,请使用 POST 请求:

    无法使用缓存文件(更新服务器上的文件或数据库)
    向服务器发送大量数据(POST 没有数据量限制)
    发送包含未知字符的用户输入时,POST 比 GET 更稳定也更可靠

    //设置传送方式,地址,以及同步还是异步
    xmlhttp.open("GET","Test.jsp?value="+escape(value),true);
    xmlhttp.onreadystatechange = callback;//状态改变的时候执行这个函数,用来判断是否请求完毕
    xmlhttp.send();//请求服务器,如果使用post方式,则send里面要带上传递的参数
    //post方式
    /**
    xmlhttp.open("POST","Test.jsp",true);
    xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
    xmlhttp.send("value="+value);
    */

    然后服务器端处理并返回,这个放在实例里面有具体代码

    在回调函数callback中设置对返回响应

    onreadystatechange 存储函数(或函数名),每当 readyState 属性改变时,就会调用该函数。
    readyState 存有 XMLHttpRequest 的状态。从 0 到 4 发生变化。

    0: 请求未初始化
    1: 服务器连接已建立
    2: 请求已接收
    3: 请求处理中
    4: 请求已完成,且响应已就绪

    status 200: “OK”

    404: 未找到页面

    相应服务器的类型

    responseText 获得字符串形式的响应数据。

    responseXML 获得 XML 形式的响应数据。 这个一般当open里面的url为xml文件的时候用

    function callback(){
    //请求完成表示
    if(xmlhttp.readyState ==4  xmlhttp.status==200){
    //设置相应操作
    }
    }
    }

    总体来说就这几个步骤,下面是详细代码

    实例

    首先创建一个文本框,用于测试用户名,并且添加监听事件onblur,意思是当失去焦点则执行,并在其后面创建个span空标签,用来动态显示信息,表示名称是否被占用

    form method="post" action="AJAX.jsp">
    table>
    tr>
    td>input type="text" id="userid" onblur="checkuser()" >span style="color: red" id="spanid">/span>/td>
    /tr>
    /table>
    /form>

    接下来是JS代码,使用AJAX把输入的内容发送到服务器,服务器来检验

    var xmlhttp;
    function checkuser(){
    var value = document.getElementById("userid").value;
    //兼容性写法创建请求实例,IE5 6支持else里面的方法
    if (window.XMLHttpRequest){
    xmlhttp = new XMLHttpRequest();
    }else {
    xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
    }
    //设置传送方式,地址,以及同步还是异步
    xmlhttp.open("GET","Test.jsp?value="+escape(value),true);
    xmlhttp.onreadystatechange = callback;//状态改变的时候执行这个函数,用来判断是否请求完毕
    xmlhttp.send();//请求服务器
    }

    然后服务器端获得数据后写回

    %
    response.setHeader("Cache-Control","no-store");//HTTP1.1
    response.setHeader("Pragma","no-cache");//HTTP1.0
    response.setDateHeader("Expires",0);//禁止在服务器中缓存
    String value = request.getParameter("value");//获取传送过来的参数
    response.getWriter().write(value);//模拟数据写回
    %>
    

    客户端再回调函数中处理服务器写回的数据

    /**
    * 回调函数
    */
    function callback(){
    //请求完成表示
    if(xmlhttp.readyState ==4  xmlhttp.status==200){
    alert(xmlhttp.responseText);//相应返回的text
    // alert(xmlhttp.responseXML);//相应返回的xml
    if (xmlhttp.responseText){//这里直接判断不为空,应该根据数据库返回值来进行不同的显示
    var spanid = document.getElementById("spanid");
    spanid.innerHTML = "注册成功";
    }
    }
    }

    效果就是当输入框失去焦点就立即判断,当然实际判断是要连接数据库的,为了简单就直接打印出来了

    以上内容是针对AJAX和JSP混合使用方法实例,希望对大家有所帮助!

    您可能感兴趣的文章:
    • 使用Ajax生成的Excel文件并下载的实例
    • jQuery ajax中使用confirm,确认是否删除的简单实例
    • 实例讲解使用原生JavaScript处理AJAX请求的方法
    • jQuery使用$.ajax提交表单完整实例
    • 实例详解angularjs和ajax的结合使用
    • jQuery Ajax使用实例
    • ThinkPHP中ajax使用实例教程
    • Ajax和$.ajax使用实例详解(推荐)
    上一篇:活到老学到老学习AJAX跨域(三)
    下一篇:登录超时给出提示跳到登录页面(ajax、导入、导出)
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    AJAX和JSP混合使用方法实例 AJAX,和,JSP,混合,使用方法,