欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

处理微信小程序异步问题

程序员文章站 2022-03-18 09:59:35
@微信小程序处理异步问题,Promise 的用法云开发过程中,处理异步问题在使用云开发的时候,往往我们会遇到异步问题,这时候我们可以使用Promise来解决。先来看看什么是异步问题var i=0;setTimeout(function(){i=1;console.log(i)}, 3000);console.log(i);按照我们的设想,会打印出(1,0),可是,事实上,会打印出(0,1);因为在js会在setTimeout还没有执行的时候,就先把下面的代码给执行了,才回来执行fun...

@微信小程序处理异步问题,Promise 的用法

云开发过程中,处理异步问题

在使用云开发的时候,往往我们会遇到异步问题,这时候我们可以使用Promise来解决。

先来看看什么是异步问题

var i=0;
setTimeout(
	function(){
	i=1;
	console.log(i)
	}
, 3000);
console.log(i);

按照我们的设想,会打印出(1,0),可是,事实上,会打印出(0,1);因为在js会在setTimeout还没有执行的时候,就先把下面的代码给执行了,才回来执行function里面的函数。

1.解决方法

先用一个异步函数把执行时间比较长的代码封装起来,例如setTimeout,或者小程序查询数据库的API。
在pages下,我们用些多一个函数,

2.声明异步函数

async dealAsync (e){
	return new Promise(function(resolve, reject){
		//可以当模板使用,在实际开发过程中,只需要改变这一部分即可
		setTimeout(
				function(){
				e=1;
				console.log(e);
				resolve(e);//用resolve可以返回你需要用的值
				}
			, 3000);
		})
}

3.调用函数

async main (e){//本来主要的函数
	var i=0;
	i=await dealAsync(i);//这里必须加上await 前面要有一个变量来接收返回值,不然可能会报错
	console(i);
}

这样,main里面就会先执行dealAsync里面的东西,再执行console(i);了

本文地址:https://blog.csdn.net/weixin_46817234/article/details/110159977