当前位置: 首页 > 编程笔记 >

Ajax核心XMLHttpRequest总结

关苗宣
2023-03-14
本文向大家介绍Ajax核心XMLHttpRequest总结,包括了Ajax核心XMLHttpRequest总结的使用技巧和注意事项,需要的朋友参考一下

Ajax:即"Asynchronous JavaScript and XML"(异步JavaScript和XML),一门综合性的技术:运用JavaScript对象XMLHttpRequest进行异步数据交换;JavaScript操作DOM实现动态效果;运用XHTML+CSS表达信息;XML和XSLT操作数据。此篇文章重点介绍使用XMLHttpRequest对象与服务器端进行异步数据交换。

    使用方法 
    XMLHttpRequest五步使用法:


    1.创建对象; 

    2.注册回调函数; 

    3.使用open方法设置和服务器交互的基本信息; 

    4.设置发送的数据,开始和服务器端交互; 

    5.实现回调函数。 

    由于每次应用XMLHttpRequest对象时,都要进行五步操作,因此,可将该对象的使用封装为js文件中,传递部分参数使用其方法就可以完成相应功能,实现如下:


    //使用封装方法人员只提供http的请求,url地址,数据,成功和失败的回调的方法 

    //1.定义XMLHttpRequest对象的构造方法 

    var MyXMLHttpRequest =function(){ 

    var xmlhttprequest; 

    if(window.XMLHttpRequest){ 

    //IE7,IE8,FireFox,Mozillar,Safari,Opera 

    //alert("IE7,IE8,FireFox,Mozillar,Safari,Opera"); 

    xmlhttprequest = new XMLHttpRequest(); 

    //解决浏览器在服务器端响应由于没有Text头的时候可能无法工作的问题 

    if(xmlhttprequest.overrideMimeType){ 

    xmlhttprequest.overrideMimeType("text/xml"); 

    } 

    }else if(window.ActiveXObject){ 

    //IE6,IE5.5,IE5 

    alert("IE6,IE5.5,IE5"); 

    var activexName =["MSXML2.XMLHTTP","Microsoft.XMLHTTP"]; 

    for (var n=0;n 

扩展问题

    1.浏览器缓存
    2.中文乱码
    3.跨域访问

    对于问题1、问题3都可以通过更改url地址的方法得以解决。问题1可在url地址尾添加时间戳,问题3通过代理方式进行解决。只需在send()中的第三步执行前添加相应判断即可:


    //解决缓存的转换:增加时间戳 

    if(url.indexOf("?") >= 0 ){ 

    url = url + "&t=" + (new Date())。valueOf(); 

    } else { 

    url = url + "?t=" + (new Date())。valueOf(); 

    } 

    //解决跨域的问题 

    if(url.indexOf("http://") >= 0) { 

    url.replace("?","&"); 

    url = "Proxy?url=" + url; 

    } 

    问题3对应代理服务端实现:


    /** 

    * Handles the HTTP GET method. 

    * 

    * @param request servlet request 

    * @param response servlet response 

    * @throws ServletException if a servlet-specific error occurs 

    * @throws IOException if an I/O error occurs 

    */ 

    @Override 

    protected void doGet(HttpServletRequest request, HttpServletResponse response) 

    throws ServletException, IOException { 

    //获取参数,最后得到请求url地址类似于:url = http://192.168…/AJAX/AJAXServer?aa=11&bb=22&cc=33 

    StringBuilder url = new StringBuilder(); 

    url.append(request.getParameter("url")); 

    //获取访问的跨域地址url = http://192.168…/AJAX/AJAXServer 

    Enumeration enu = request.getParameterNames(); 

    boolean flag = false;       //定义标志变量,表示是否为拼接的第一个参数 

    while(enu.hasMoreElements()){ 

    String paramName = (String) enu.nextElement(); 

    if(!paramName.equals("url")){ 

    String paramValue = request.getParameter(paramName); 

    paramValue = URLEncoder.encode(paramValue,"utf-8"); 

    if(!flag){ 

    url.append("?")。append(paramName)。append("=")。append(paramValue); 

    flag = true; 

    } else { 

    url.append("&")。append(paramName)。append("=")。append(paramValue); 

    } 

    } 

    } 

    response.setContentType("text/html;charset=utf-8"); 

    PrintWriter out = response.getWriter(); 

    if(url != null && url.length() > 0){ 

    URL connectionUrl = new URL(url.toString()); 

    BufferedReader reader = new BufferedReader(new InputStreamReader(connectionUrl.openStream(),"utf-8"));

以上就是本文的全部内容了,希望大家能够喜欢。

 类似资料:
  • 本文向大家介绍Vue核心概念Action的总结,包括了Vue核心概念Action的总结的使用技巧和注意事项,需要的朋友参考一下 Action 类似于mutation,不同在于: - Action 提交的是mutation,而不是直接变更状态。 - Action 可以包含任意异步操作。 Action 函数接受一个与 store 实例具有相同方法和属性的 context 对象,因此你可以调用 cont

  • 问题内容: 我正在尝试使用POST方法编写XMLHttpRequest。我过去已经使用GET方法设法使用XMLHttpRequest,但是在POST方面却很挣扎。 这是我的代码: 它基本上调用PHP脚本,然后将一些信息添加到数据库中。 问题答案: 好吧,我已经设法对它进行了排序。 奇怪的原因虽然可能与沙箱安全性有关,但是我没有使用完整的URL地址,而是使用了文件的相对路径,现在可以使用了。 谢谢大

  • .NET核心和ASP.NET核心到底有什么区别?

  • 问题内容: 我在JavaScript中使用。但是,这给了我一个错误,我不知道我的问题是什么。 我必须解析一个XML文件并将其内容分配给网页-这是我的代码: 我的XML文件在同一目录中。 仅供参考,我通常使用C#或Java进行编程,并且我在Google Chrome上运行我的网站。 问题答案: 因此,这里可能有些错误。 首先,请先阅读如何使用,因为还有第三个可选参数用于指定是否发出异步请求, 默认为

  • 19.2 核心与核心模块 谈完了整个开机的流程,您应该会知道,在整个开机的过程当中,是否能够成功的驱动我们主机的硬件配备, 是核心 (kernel) 的工作!而核心一般都是压缩文件,因此在使用核心之前,就得要将他解压缩后,才能载入内存当中。 另外,为了应付日新月异的硬件,目前的核心都是具有“可读取模块化驱动程序”的功能, 亦即是所谓的“ modules (模块化)”的功能啦!所谓的模块化可以将他想

  • 主要内容:创建一个核心,使用create命令,使用create_core命令,删除核心Solr核心(Core)是Lucene索引的运行实例,包含使用它所需的所有Solr配置文件。我们需要创建一个Solr Core来执行索引和分析等操作。 Solr应用程序可以包含一个或多个核心。 如果需要,Solr应用程序中的两个核心可以相互通信。 创建一个核心 安装和启动Solr后,可以连接到Solr的客户端(Web界面)。访问以下网址: http://Localhost:8983/solr/ 如