异步处理

js将任务执行分为同步队列和异步队列

同步队列中,会先等待上一个任务执行完毕,再执行下一个任务
异步队列中,所有任务同时执行

定时器,IO操作,网络请求都会进入异步队列,不会等待上一个任务执行完毕,再执行下一个任务,但有些任务需要等待这些任务执行完毕再执行

promise

new Promise((resolve,reject)=>{
	setTimeout(()=>{
		resolve('done')
	},2000)
}).then(res=>{
	console.log(res)	
})

promise对象接收一个函数,并负责该函数执行,函数的两个分别参数为resolve,reject的函数。
如果执行成功,将调用resolve
如果失败,调用reject

Promise.all

Promise.all([new Promise((resolve,reject)=>{
	setTimeout(()=>{
		resolve('done2')
	},3000)
}),new Promise((resolve,reject)=>{
	setTimeout(()=>{
		resolve('done1')
	},1000)
})]).then((res)=>{
	console.log(res)
})

同时执行两个任务,并在两个任务都执行完毕后执行then

Promise.race

Promise.race([new Promise((resolve,reject)=>{
	setTimeout(()=>{
		resolve('done2')
	},3000)
}),new Promise((resolve,reject)=>{
	setTimeout(()=>{
		resolve('done1')
	},1000)
})]).then(res=>{
	console.log(res)
})

同时执行两个任务,then获得任务较快获得结果的并执行

async await

(async ()=>{
	let res = await new Promise((resolve,reject)=>{
		setTimeout(()=>{
			resolve('1s')
		},1000)
	})
	console.log(res)
})()
(async ()=>{
	let res = await new Promise((resolve,reject)=>{
		setTimeout(()=>{
			resolve('1s')
		},1000)
	})
	console.log(res)
	let res2 = await new Promise((resolve,reject)=>{
		setTimeout(()=>{
			resolve('2s')
		},2000)
	})
	console.log(res2)
})()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值