Я столкнулся с проблемой, что функция getVideoDetails возвращает object Promise как объект, в то время как мне нужен простой объект, который я могу вернуть другой функции getTrendingVideos.
Кто-нибудь может помочь?
export class YoutubeService {
getTrendingVideos() {
var params = {
part: 'snippet',
chart: 'mostPopular',
regionCode: 'GB',
maxResults: '24',
key: config.youtubeApi.key
};
var result = [];
return axios.get('/', {params}).then(function(res){
result = res.data.items;
for (var i = 0; i < result.length; i++) {
result[i] = {
id: result[i].id,
title: result[i].snippet.title,
thumbnail: result[i].snippet.thumbnails.high.url,
publishedAt: moment(result[i].snippet.publishedAt).fromNow()
};
//**Below line Returning a promise object**
result[i] = YoutubeService.getVideoDetails(result[i]);
}
return result;
});
}
static getVideoDetails(video) {
var params = {
part: 'statistics',
id: video.id,
key: config.youtubeApi.key
};
return axios.get('/', {params}).then(function(res) {
var result = res.data;
video.viewCount = result['items'][0].statistics.viewCount;
video.likeCount = result['items'][0].statistics.likeCount;
return video;
});
}
}
Я пытался исправить ваш код, когда я обнаружил странный код, в котором вы назначаете result[i] = {...}, а затем в следующей строке вы назначаете что-то еще для result[i]. Для меня это не имело смысла, поэтому я не понимал, что вы на самом деле пытались с этим сделать.





Просто добавьте вызов Promise.all(). Ваши функции getTrendingVideos() в любом случае уже возвращают обещание.
getTrendingVideos() {
const params = {…};
return axios.get('/', {params}).then(function(res){
const promises = res.data.items.map(item => {
const video = {
id: item.id,
title: item.snippet.title,
thumbnail: item.snippet.thumbnails.high.url,
publishedAt: moment(item.snippet.publishedAt).fromNow()
};
// Below line is returning a promise object, **and that's ok**
return YoutubeService.getVideoDetails(video);
});
return Promise.all(promises);
// ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
});
}
Он асинхронно загружает значение из Интернета. Невозможно сразу вернуть значение, которое будет доступно только в будущем.