ajax 发送异步请求

我们知道 ajax 可以发送异步请求,但是有时候发送异步请求时会出现意想不到的错误,今天我来分析一下这个问题;

首先需要引入 jQuery.js ,看下面代码

$(function(){
	$("#btn").click(function(){
		$.ajax({
			type:"POST",
			dataType:"text",
			url:"login/login.do",
			data:"name=tom",
			success:function(mess){
				if (mess == "true") {
					alert("服务端响应完毕!");
				} 
			},
			error:function(){
				alert("出错了!");
			}
                });
		alert("发送异步请求完毕!");
	});
});

这段代码执行时,会先执行 "发送异步请求完毕!"  然后才执行 "服务端响应完毕!"  ,这显然有问题,服务端都没有处理完,请求已经完成了,

相当于服务端处理数据太迟了,所以,有时候我们也需要 ajax 发送同步请求,就不会出现这样的问题了,如下面代码:

$(function(){
	$("#btn").click(function(){
		$.ajax({
			type:"POST",
			dataType:"text",
			url:"login/login.do",
			data:"name=tom",
			async:false,
			success:function(mess){
				if (mess == "true") {
					alert("服务端响应完毕!");
				} 
			},
			error:function(){
				alert("出错了!");
			}
                });
		alert("发送异步请求完毕!");
	});
});
加上 async:false, 发送的是同步请求,这样就会等到服务端处理完数据之后,在结束请求;

很多时候 ajax 都发送异步请求,有时候难免会出现这样的错误,只要让其发送同步请求就不会出现了.


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值