首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >回报承诺,立即解决

回报承诺,立即解决
EN

Stack Overflow用户
提问于 2018-05-09 21:30:01
回答 1查看 69关注 0票数 0

我需要我的函数返回一个承诺,在它创建的承诺被返回到调用它的函数之后立即解析。

现在我有一个:

代码语言:javascript
复制
class BrandsDataFetcher extends BaseDataFetcher {
    getBrands() {
        const p = new Promise((resolve, reject) => resolve());  
        p.then(() => {
            return {'a': 1, 'b': 2};
        }); 
        return p; 
    }
}

但是,在调用此函数的函数中,它得到的数据未定义:

代码语言:javascript
复制
const brandsDataFetcher = new BrandsDataFetcher();
return brandsDataFetcher.getBrands()
    .then((data) => {
        console.log(typeof(data));   // 'undefined'

有人知道为什么会发生这种事吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-05-09 21:36:23

您返回的是原始承诺,而不是then的返回值。

代码语言:javascript
复制
const p = new Promise((resolve, reject) => resolve());
const q = p.then(() => {
    return {'a': 1, 'b': 2};
});        // q would return your object...
return p;  // but you return the original p instead!

这样做的惯用方法是使用Promise.resolve(value)

代码语言:javascript
复制
class BrandsDataFetcher extends BaseDataFetcher {
    getBrands() {
        return Promise.resolve({'a': 1, 'b': 2}); 
    }
}
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50262359

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档