微信小程序:JS异步请求回调

做前端会用到异步请求需要回调的情况,这也应该是前端常遇到的一个问题。

搜了一下,大概解决的方式有两种
(一)通过嵌套的方式来解决-----(笨法,但是有用)
(二)promise-----(第二部分,准备自己测试一遍,验证成功再另写一片详细的)

讲的白话一点就是A 方法和B 方法这样的两个方法,A会有个网络请求B方法要依赖与A方法的请求(其实不单单是网络请求,任何只要B依赖于A的返回值或者结果,都会有影响,只不过网络请求常会遇到这样的问题,请求超时或者请求时间,都会引起问题。),A还没有处理完结果,B就开始操作肯定有问题的,所以要等A完成后才开始调用B,

顺序是这样的
A -----》A done ------》B

问题代码大概这样的

onLoad:function(){
   mainMethod()
}
mainMethod:function(){
	this.A():
	this.B();
}

A:function(){
	request( url  ,params,  functiom (res){
		this.data.result = res.data 
	})
}

B:function(){
	if(this.data.result){
		_count = result.count;
		_payNum = (_count /100 ).toFixed(2);
		_this.payNum = _payNum;
	}
}

从人的直觉上看貌似也没什么问题,忽略一个问题就是,虽然JS是同步的,但执行请求是异步的。

执行this.A()

猜你喜欢

转载自blog.csdn.net/FeiChangWuRao/article/details/90082089