ajax里面async true,Ajax请求中的async:false/true的区别

Ajax请求中的async:false/true的区别

官方的解释是:

asyncBooleanDefault:true

Bydefault,allrequestsaresentasynchronous(e.g.thisissettotruebydefault).Ifyouneedsynchronousrequests,setthisoptiontofalse.Notethatsynchronousrequestsmaytemporarilylockthebrowser,disablinganyactionswhiletherequestisactive.

async.默认是true,即为异步方式,$.Ajax执行后,会继续执行ajax后面的脚本,直到服务器端返回数据后,触发$.Ajax里的success方法,这时候执行的是两个线程。若要将其设置为false,则所有的请求均为同步请求,在没有返回值之前,同步请求将锁住浏览器,用户其它操作必须等待请求完成才可以执行。

jsp页面:

functionjudgeSupplierAssessment(){

varresult=false;

varquote_list_id=$("input[name='quote_list_id']").val();

varproduct_id=$("#product_id").val();

varurl="?

quote_list_id="+quote_list_id+"&product_id="+product_id;

$.ajax({

url:encodeURI(url),//处理中文乱码。

type:"POST",//请求的方式:"POST"或者"GET"

dataType:"json",//数据返回的格式

async:false,

success:function(obj){

varflag=obj['flag'];

if(flag=='1'){

result=true;

}

},

error:errorCallBaxk//请求失败后回调函数

});

returnresult;

alert(result);

}

这个ajax请求为同步请求,在没有返回值之前,alert(result)是不会执行的。

如果async设置为:true,则不会等待ajax请求返回的结果,会直接执行ajax后面的语句。

publicStringcheckSupplierAssessment()throwsIOException{

HttpServletRequestrequest=Struts2Utils.getRequest();

SystemUsersystemUser=getUser(request);

Stringpro_id=request.getParameter("product_id");

Stringquote_list_id=request.getParameter("quote_list_id");

PrintWriterout=Struts2Utils.getResponse().getWriter();

HttpServletResponseresponse=Struts2Utils.getResponse();

Mapmap=newHashMap();

Stringflag=orderQuoteService.judgeSupplierAssessment

(pro_id,quote_list_id,systemUser);

map.put("flag",flag);

Gsongson=newGson();

Stringjson=gson.toJson(map);

response.setHeader("Cache-Control","no-cache");

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

out.print(json);

out.flush();

returnnull@H_79_403@;

}

总结

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值