Vue:执行完一个函数再执行另一个函数(Promise用法)

几个活动同时进行,开始结束时间不同。在点击报名时间需检测是否在活动期间。需要异步获取活动时间并跟当前时间进行比较。这里用到了Promise

data(){
  return{
    activeStart:"",//活动开始时间
    activeEnd:"",//活动结束时间

  }
},
methods:{
  //获取活动时间(方法一)
  getActiveTime(event){
    return new Promise((resolve, reject) => {
    
    /*后台数据获取过程成功*/
        
        if (response.data.status==1) {
          console.log(response.data.data)
          this.activeStart = new Date(response.data.data.start_time.replace(/-/g,"/")).getTime();
          this.activeEnd  = new Date(response.data.data.end_time.replace(/-/g,"/")).getTime();
          resolve(this.activeStart,this.activeEnd) //resolve()返回数据
        }else{
          console.log(response);
        }
        
     /*后台获取数据通过resolve()返回数据*/

    })
  },

  //科技辅导员培训一期(方法二)
  checkNameOne(){
    Promise.all([
      this.getActiveTime(101) //101是活动id后台获取时间需要提供的,可忽略
    //this.otherMethods()  其他需要执行的方法
    ]).then(res => {

       console.log("其他代码段")

    })
  },
}

也可以这样: 

funOne(){
  return new Promise((resolve, reject) => {
  //需要执行的代码
    resolve(/*需要返回的数据*/)
  });
},

funTwo(){
  return new Promise((resolve, reject) => {
  //需要执行的代码
    resolve(/*需要返回的数据*/)
  });
},

// 调用
funCall(){
  //funOne() 先执行再执行funTwo()
  this.funOne().then(val => {

    this.funTwo();

  });
},

//按照顺序调用多个方法
runFunAll(){
  Promise.all([
    this.funOne(),
    this.funTwo(),
    /*
    this.funThree(),
    this.funOther(),
    */
  ]).then(res => {
    //需要执行的代码
    console.log("按顺序从上到下执行方法结束后再执行此处");
  })
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值