异步方法总是返回 undefined
async method always returning undefined
我无法解决这个问题,所以我在这里问:
这是异步函数,如您所见,return正在处理一个数组。但它 return 是一个未定义的值。
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
}
只有当我在函数外声明变量并且函数不return任何东西而只改变数组内容时它才有效。
正如所写,您的函数 必须 return 一个数组(空或其他)。如果它是 returning undefined
,那么您将生成一个异常并且应该通过您的 catch 语句在控制台中看到一个异常。如果您没有看到它,您可以尝试删除 try/catch 并查看出现了什么异常。
其实我已经解决了这个问题。它返回一个字符串,所以我不得不使用 JSON.parse(request) 所以我有一个可以处理的对象。
我无法解决这个问题,所以我在这里问:
这是异步函数,如您所见,return正在处理一个数组。但它 return 是一个未定义的值。
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
}
只有当我在函数外声明变量并且函数不return任何东西而只改变数组内容时它才有效。
正如所写,您的函数 必须 return 一个数组(空或其他)。如果它是 returning undefined
,那么您将生成一个异常并且应该通过您的 catch 语句在控制台中看到一个异常。如果您没有看到它,您可以尝试删除 try/catch 并查看出现了什么异常。
其实我已经解决了这个问题。它返回一个字符串,所以我不得不使用 JSON.parse(request) 所以我有一个可以处理的对象。