【问题标题】:async method always returning undefined异步方法总是返回 undefined
【发布时间】:2019-05-30 01:04:41
【问题描述】:

我无法解决这个问题,所以我在这里问:

这是异步函数,如您所见,它返回一个数组。但它返回一个未定义的值。

async function scrape(pageURL) {
var dealArray = [];
try {
    const browser = await puppeteer.launch({ headless: true });
    const page = await browser.newPage();
    await page.goto(pageURL);
    await page.waitForSelector('div.s-item-container');
    const dealsElements = await page.$$('div.s-item-container');
    for(deal of dealsElements) {
        let dealTitleElement = await deal.$('div.s-item-container a.s-access-detail-page');
        let dealTitleValue = await (await dealTitleElement.getProperty('title')).jsonValue();
        let dealPriceElement= await deal.$('div.s-item-container span.a-color-price');
        let dealPriceValue = await (await dealPriceElement.getProperty('textContent')).jsonValue();
        let dealReviewsElement = await deal.$('div.s-item-container .a-icon-star');
        let dealLinkValue = await (await dealTitleElement.getProperty('href')).jsonValue() + '&tag=dragonstv-21';
        let dealReviewsClass = await (await dealReviewsElement.getProperty('className')).jsonValue();
        let dealReviewsValue;
        if(dealReviewsClass) {
            let starValue = dealReviewsClass.substring(26);
                if(starValue.indexOf('-') === -1) {
                    dealReviewsValue = starValue;
                } else {
                    let stars = starValue.replace('-', '.');
                    dealReviewsValue = stars;
                }
        }
        dealArray.push({
            "title": dealTitleValue,
            "price": dealPriceValue,
            "reviews": dealReviewsValue + "/5.0",
            "link": dealLinkValue,
            "store": "Amazon",
        });
    }
    return Promise.resolve(dealArray);
} catch(e) {
    console.error('Error: ' + e);
}
}

我是这样称呼它的:

scrape('working link').then((data) => {
    console.log(data) // result: undefined
}

只有当我在函数之外声明变量并且函数不返回任何内容而只更改数组内容时,它才有效。

【问题讨论】:

  • 请注意,由于您的函数是使用 async 关键字声明的,因此您不需要显式返回带有 return Promise.resolve(dealArray) 的承诺。您可以简单地 return dealArray 并且由于 async 关键字,它将被包装在一个承诺中。

标签: javascript node.js asynchronous puppeteer


【解决方案1】:

正如所写,您的函数必须返回一个数组(空或其他)。如果它返回undefined,那么您正在生成一个异常,并且应该通过您的catch 语句在控制台中看到一个异常。如果您没有看到它,您可以尝试删除 try/catch 并查看出现了哪些异常。

【讨论】:

  • 似乎最后一次迭代给出了一个空值。我要自己解决。
【解决方案2】:

我实际上已经解决了问题。它返回了一个字符串,所以我不得不使用 JSON.parse(request) 所以我有一个可以处理的对象。

【讨论】:

    猜你喜欢
    • 2016-07-01
    • 2017-03-18
    • 2016-01-16
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-09-05
    • 2019-06-27
    • 2015-08-11
    相关资源
    最近更新 更多