vue - promise 用法

本文介绍了在Vue中使用Promise处理异步操作的场景。通过模拟未使用Promise的情况,展示了异步执行导致的顺序问题。然后,通过使用Promise将异步网络请求队列化,并按预期顺序处理,以确保正确执行后续逻辑。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用场景

有异步代码的时候,可以将异步操作队列化,按照期望的顺序执行。
如,网络请求过程是异步,我们要完成异步网络请求后,处理我们的后续逻辑。

模拟 - 未使用promise 情况

我们可以用setTimeout,模拟异步情况,setTimeout 里面的方法等于是在异步执行

// 调用
function1(){
  this.function2();
  this.function3();
},

function2(){
	setTimeout(()=>{
	  //把异步执行的代码放到这里去
	  console.info('function2')
	},2000)        
},

function3(){
     console.info('function3')
}

上面情况, 日志是先打印function3,然后是function2。

模拟 - 使用promise 情况

  1. 使用promise包住异步方法
  2. 使用resolve 返回数据
  3. 用then按序处理,获取resole返回结果
// 调用
function1(){
    this.function2().then(val => { 
		// 打印方法2返回的数据
		console.info(JSON.stringify(val))
		this.function3();
    });
},

function2(obj){
    return new Promise((resolve, reject) => {
        setTimeout(()=>{
          //把异步执行的代码放到这里去
          console.info('function2')
		  // Promise 中用 resolve 返回数据,下一个方法在then中获取
          return resolve({name:555});
        },2000)        
    })	
},

function3(){
     console.info('function3')
}

打印日志结果
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值