设为首页收藏本站

就爱编程论坛

 找回密码
 注册

人人连接登陆

无需注册,直接登录

用新浪微博连接

一步搞定

QQ登录

只需一步,快速开始

查看: 382|回复: 0
打印 上一主题 下一主题

AJAX中的请求方式以及同步异步的区别 [复制链接]

Rank: 9Rank: 9Rank: 9

  • TA的每日心情
    无聊
    2025-5-27 03:37:20
  • 签到天数: 366 天

    [LV.9]以坛为家II

    论坛先锋 学习至圣 荣誉成员 论坛元老 活跃之星 终极领袖

    我玩的应用:

    跳转到指定楼层
    楼主
    发表于 2011-6-21 11:26:21 |只看该作者 |正序浏览
    请求方式,分为GET与POST:

    GET

    最为常见的HTTP请求,普通上网浏览页面就是GET。GET方式的参数请求直接跟在URL后,以问号开始。(JS中用window.location.search获得)。参数可以用encodeURIComponent进行编码,使用方式:


    <CODE>var EnParam = encodeURIComponent(param);</CODE>


    URL只支持大约2K的长度,即2048字符数;使用GET进行AJAX请求时候会缓存导致出现的页面不是正确的,一般方法加random参数值;ajax.send(null)。
    POST
    向服务器提交数据用到。
    需要将form表单中的值先取出转换成字符串,用&符号连接,(同GET传参数一样);提交数据量2GB ;使用ajax.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded'),处理提交的字符串;ajax.send(strings),这个strings表示form中需要提交的内容,例如a=1&b=2类似这样的字符串。

    同步与异步:

    举个例子:普通B/S模式(同步)AJAX技术(异步)
    同步:提交请求->等待服务器处理->处理完毕返回 这个期间客户端浏览器不能干任何事
    异步: 请求通过事件触发->服务器处理(这是浏览器仍然可以作其他事情)->处理完毕


    ajax.open方法中,第3个参数是设同步或者异步。prototype等js类库一般都默认为异步,即设为true。先说下同步的情况下,js会等待请求返回,获取status。不需要onreadystatechange事件处理函数。而异步则需要onreadystatechange事件处理,且值为4再正确处理下面的内容。


    //同步传输模式
    function RequestByGet(nProducttemp,nCountrytemp)
    {
        var xmlhttp
        if (window.XMLHttpRequest)  
        {  
             //isIE   =   false;  
             xmlhttp   =   new   XMLHttpRequest();  
        }  
        else if (window.ActiveXObject)
        {  
             //isIE   =   true;  
             xmlhttp   =   new   ActiveXObject("Microsoft.XMLHTTP");  
        }
                     
        //Web page location.
        var URL="http://www.baidu.com/;
        xmlhttp.open("GET",URL, false);
        //xmlhttp.SetRequestHeader("Content-Type","text/html; charset=Shift_JIS")
        xmlhttp.send(null);
        var result = xmlhttp.status;
       
        //OK
        if(result==200)
        {
            document.getElementById("div_RightBarBody").innerHTML=xmlhttp.responseText;
        }
        xmlhttp = null;

    }

    //异步传输模式
    var xmlhttp
    function RequestByGet(nProducttemp,nCountrytemp)
    {

        if (window.XMLHttpRequest)  
        {  
             //isIE   =   false;  
             xmlhttp   =   new   XMLHttpRequest();  
        }  
        else if (window.ActiveXObject)
        {  
             //isIE   =   true;  
             xmlhttp   =   new   ActiveXObject("Microsoft.XMLHTTP");  
        }
                     
        //Web page location.
        var URL="http://www.baidu.com/";
        xmlhttp.open("GET",URL, true);
        xmlhttp.onreadystatechange = handleResponse;
        //xmlhttp.SetRequestHeader("Content-Type","text/html; charset=UTF-8")
        xmlhttp.send(null);  

    }
    function handleResponse()
    {

        if(xmlhttp.readyState == 4 && xmlhttp.status==200)
        {
            document.getElementById("div_RightBarBody").innerHTML=xmlhttp.responseText;
            xmlhttp = null;
        }

    }
    ===============================================

    举个例子:普通B/S模式(同步)AJAX技术(异步)
    同步:提交请求->等待服务器处理->处理完毕返回 这个期间客户端浏览器不能干任何事
    异步: 请求通过事件触发->服务器处理(这是浏览器仍然可以作其他事情)->处理完毕
    --------------------------------------------------------------------------------------------------------------------
    同步就是你叫我去吃饭,我听到了就和你去吃饭;如果没有听到,你就不停的叫,直到我告诉你听到了,才一起去吃饭。
    异步就是你叫我,然后自己去吃饭,我得到消息后可能立即走,也可能等到下班才去吃饭。

    所以,要我请你吃饭就用同步的方法,要请我吃饭就用异步的方法,这样你可以省钱。
    --------------------------------------------------------------------------------------------------------------------
    举个例子 打电话时同步 发消息是异步

    看看open方法的几个参数。
    .open (http-method, url, async, userID, password)
    (后面是帐号和密码,在禁止匿名访问的http页面中,需要用户名和口令)
    首先看看异步处理方式。
    其中async是一个布尔值。如果是异步通信方式(true),客户机就不等待服务器的响应;如果是同步方式(false),客户机就要等到服务器返回消息后才去执行其他操作。我们需要根据实际需要来指定同步方式,在某些页面中,可能会发出多个请求,甚至是有组织有计划有队形大规模的高强度的request,而后一个是会覆盖前一个的,这个时候当然要指定同步方式:Flase。
    分享到: QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    分享分享0 收藏收藏0 支持支持0 反对反对0 分享到人人 转发到微博
    [img=http://mail.qq.com/cgi-bin/qm_share?t=qm_mailme&email=fRUcHhYWGAQ9GxIFEBwUEVMeEhA]http://rescdn.qqmail.com/zh_CN/htmledition/images/function/qm_open/ico_mailme_02.png[/img]

    使用道具 举报

    您需要登录后才可以回帖 登录 | 注册 人人连接登陆

    晴云孤魂's Blog|就爱编程搜帖|手机版|Archiver|就爱编程论坛     

    GMT+8, 2025-7-2 09:26 , Processed in 0.101269 second(s), 27 queries .

    Powered by Discuz! X2

    © 2001-2011 Comsenz Inc.

    回顶部