使用ajax php运行顺序,JS中AJAX执行顺序解决问题详情(附解决办法)

本文探讨了JavaScript中AJAX异步执行导致的顺序问题,并提供了两种解决方案。一种是将AJAX设置为同步(async:false),但这可能导致页面假死。另一种常见方法是将依赖AJAX回调的代码放入success函数内,确保执行顺序。通过调整代码结构,可以避免因异步执行而产生的逻辑错误。
摘要由CSDN通过智能技术生成

本篇文章主要的解释了关于js中ajax执行顺序解决的问题,现在让我们来看看这篇关于ajax的执行顺序解决的文章吧

在JS中我们会遇到执行顺序的问题,尤其是AJAX的执行顺序,js中默认的执行顺序是从上往下执行。

看下面的一段代码callback:function(value, validator, $field){

$.ajax({

url : window.ctx+"/sys/manager/validateLoginName",

data:{loginName:value},

type : 'post',

dataType : "json",

async:true,

success: function(result){

if(result!=null)

globalVariable.flag=result;

alert(1)

}});

alert(2)

if(globalVariable.flag!=1)return true;

if(globalVariable.flag==1)return false;

}

由于这里的AJAX是异步请求,所以在浏览器中会先弹出2在弹出1

这样就会出现问题 假如flag默认是0,在执行完AJAX之后会变成1,那么if语句其实是用0去做的判断,与我们的目的不相符,我们想要的是用AJAX执行完之后赋值的flag去做if判断(想看更多就到PHP中文网AJAX开发手册栏目中学习)

解决:

第一种方法

之所以出现这样的问题是因为AJAX采用了异步请求,所以如果我们想先弹出1再弹出2只需要把AJAX改为同步即可,也就是将async改为false

这样如果AJAX没有执行完页面会出现假死状态,停止往下执行,只有当AJAX回调走完以后才会往下走

当然我们使用AJAX就是为了异步,所以上面的方法是遇到特殊的需要了可以这样处理

第二种方法

第二种办法是比较常用的

例如下面一段代码function test(){

$.ajax({

url : window.ctx+"/sys/manager/addUserRole",

data:formData,

type : 'post',

dataType : "json",

processData:false,

contentType:false,

success: function(result){

if(result!=null){

testCallback();

}

}});

test2();

}

function testCallback(){

alert(1)

}

function test2(){

alert(2)

}

AJAX是异步的,我们希望先弹出1再弹出2我们只需要把test2放在test的回调函数中即可

像这样function test(){

$.ajax({

url : window.ctx+"/sys/manager/addUserRole",

data:formData,

type : 'post',

dataType : "json",

processData:false,

contentType:false,

success: function(result){

if(result!=null){

testCallback();

}

}});

}

function testCallback(){

alert(1)

test2()

}

function test2(){

alert(2)

}

本篇文章到这就结束了(想看更多就到PHP中文网AJAX使用手册栏目中学习),有问题的可以在下方留言提问。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值