zoukankan      html  css  js  c++  java
  • ajax 同步请求和异步请求的差异

    ajax 同步请求和异步请求的差异分析

    2011-7-5 asp之家 网友评论0投递文章

     

     

    ajax 同步请求和异步请求的差异分析,需要的朋友可以参考下。

    代码一:


    Synchronize = function(url,param) {
    function createXhrObject() {
    var http;
    var activeX = [ "MSXML2.XMLHTTP.3.0", "MSXML2.XMLHTTP", "Microsoft.XMLHTTP" ];
    try {
    http = new XMLHttpRequest;
    } catch (e) {
    for (var i = 0; i < activeX.length; ++i) {
    try {
    http = new ActiveXObject(activeX[i]);
    break;
    } catch (e) {}
    }
    } finally {
    return http;
    }
    }
    var conn = createXhrObject();
    conn.open("POST", url, false);//ajax同步
    conn.send(param);
    var strReturn = conn.responseText;
    alert("1");
    if (strReturn != "") {
    return Ext.decode(conn.responseText);
    } else {
    return null;
    }
    alert("2");
    };

    代码二:
    Ajax 同步请求方式:


    Synchronize = function(url,param) {
    function createXhrObject() {
    var http;
    var activeX = [ "MSXML2.XMLHTTP.3.0", "MSXML2.XMLHTTP", "Microsoft.XMLHTTP" ];
    try {
    http = new XMLHttpRequest;
    } catch (e) {
    for (var i = 0; i < activeX.length; ++i) {
    try {
    http = new ActiveXObject(activeX[i]);
    break;
    } catch (e) {}
    }
    } finally {
    return http;
    }
    }
    var conn = createXhrObject();
    conn.open("POST", url, true);//ajax异步
    conn.send(param);
    var strReturn = conn.responseText;
    alert("1");
    if (strReturn != "") {
    return Ext.decode(conn.responseText);
    } else {
    return null;
    }
    alert("2");
    };

    同步和异步的差异如下:

    conn.open('POST',Url,true); // ajax异步
    conn.open('POST',Url,false); // ajax同步

    对于代码二,为异步的ajax请求,执行结果为:先执行alert(2)再执行alert(1), 异步的意思就是说一旦conn.open请求一发出,前端不去等待它的响应便执行后面的代码,所以alert(2)先执行了,然后当响应response 到达以后才执行alert(1);

    对于代码一,为同步的ajax请求,执行结果为:先执行alert(1)再执行alert(2), 同步的意思就是说一旦conn.open请求一发出,前端就去等待它的响应,响应完成以后,alert(1)先执行了,然后alert(2);

     

  • 相关阅读:
    一次linux启动故障记录
    linux 时间相关的一些总结
    linux 3.10 gro的理解和改进
    linux 3.10 的中断收包笔记
    一个有趣的nginx问题引发的小问题
    linux 3.10 tcp的accept测试
    linux mce的一些相关内容和用户态监控的设计方法
    C/C++(基础-运算符详解)
    C/C++(基础-常量,类型转换)
    C/C++(基础编码-补码详解)
  • 原文地址:https://www.cnblogs.com/gaoxue/p/2438882.html
Copyright © 2011-2022 走看看