jquery中使用ajax的同步异步问题

<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript">
$(function(){
	$("#bt").click(function(){
		var s=checkcode(5);
		alert(s);
	})
	function checkcode(i){
		var returnValue;
		var options={
			type:"get",
			url:"test.php",
			async:true, 
			dataType:"html",
			success:function(result){
				if(result==123)
					returnValue=1;
			}
		}
		$.ajax(options);
		return returnValue;
	}
})
</script>
<input type="button" id="bt"/>

其中,test.php的代码如下:

<?php
echo 123;
?>

默认情况下,使用ajax的方式是异步的,所以说,在jquery向test.php发出连接请求时,会同时执行return returnValue这条语句,因此,返回的是空,而当async的值设置为false后,会使用同步的方式,在等待其完成请求,执行success方法后才会接着执行return returnValue这条语句,因此,这个时候能够得到返回值。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值