ajax同步请求和异步请求

本文通过两个示例代码对比介绍了AJAX同步与异步请求的区别。在异步请求中,前端会继续执行后续代码而不等待服务器响应,使得用户交互更加流畅;而在同步请求中,前端将等待服务器响应完成后才会继续执行后续代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这里讲解一下ajax同步和异步的差异, 先看2段代码:

代码一:

function PostAsynToServer(Url,Param){

        var obj;

       

        if(window.ActiveXObject)

        {

            obj=new ActiveXObject('Microsoft.XMLHTTP');

        }

        else if(window.XMLHttpRequest)

        {

            obj=new XMLHttpRequest();

        }

        obj.open('POST',Url,true);

        obj.send(Param);

       var strReturn = obj.responseText;

       alert(1);

}

PostAsynToServer(url, null);

alert(2);

 

代码二:

function postToServer(Url,Param){

        var obj;

       

        if(window.ActiveXObject)

        {

            obj=new ActiveXObject('Microsoft.XMLHTTP');

        }

        else if(window.XMLHttpRequest)

        {

            obj=new XMLHttpRequest();

        }

        obj.open('POST',Url,false);

        obj.setRequestHeader('Content-Type','application/x-www-form-urlencoded');

        obj.send(Param);

        var strReturn=obj.responseText;

        alert(1);

}

postToServer(url, null);

alert(2);

 

同步和异步的差异如下:

obj.open('POST',Url,true);         // ajax异步

obj.open('POST',Url,false);        // ajax同步

 

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

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

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值