关于promise的问题

a () {
    return new Promise((res, rej) => {
        //用接口获取数据 ,写法如下比如:
        getData().then(res => {
            this.data = res.data.reslut
            console.log(this.data)
        })
    });
}

vue中这样定义了a方法, 并且在一个按钮的点击事件中调用a方法,想要的效果就是希望执行完a方法后,再执行alert,如下:

click () {
    this.a().then(()=> {
        alert(11)
    })
}

这样调用中a方法是生效了,但是 后面的alert(11)并未触发, 是哪里错了吗? 还是写的根本就是错的,请大神指点指点。

阅读 2.3k
3 个回答
a () {
    return new Promise((resolve,reject) => {
        getData().then(res => {
            this.data = res.data.reslut
            console.log(this.data)
            resolve(this.data);
        })
    });
}

你没有用 resolve 改变promise状态,所以没有到 then 回调中去。代码楼上已经给出了,就不再赘述了

resolve将promise对象当前的状态变为成功,reject将promise对象当前的状态变为失败,状态改变后才会继续执行then

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题