Promise.map中的Promise.map

时间:2017-03-03 18:51:50

标签: javascript jquery node.js promise bluebird

我尝试使用Promise.mapSeries / Promise.map中的Bluebird的Promise.mapSeries / Promise.map返回JSON对象,但我无法正确返回它们。功能如下:

function getMovieDetails(link){
return new Promise(function(resolve, reject) {
    request(link, function(error, response, body){
        var request = Promise.promisifyAll(require("request"), {multiArgs: true});

        var $ = cheerio.load(body);

        var movieYears = "Years";
        var movieYearLinks = [];

        movieYearLinks.each(function(index, item) {
            var movieYear = $(item).text();
            var movieYearLink = $(item).attr("href");
            movieYearLinks.push(movieYearLink);
        });

        Promise.mapSeries(movieYearLinks, function(url) {
            return request.getAsync(url).spread(function(response,body) {
                var $ = cheerio.load(body);
                var movie = {};
                var year = "YEAR".text();

                movie["year"] = year;

                var movieActorsArray = [];
                movieActors.each(function(index, item){
                    var movieActor = $(item).text();
                    movieActorsArray.push(movieActor);
                });
                movie["movieActors"] = movieActorsArray;

                var recommendedMovies = //SOME ROWS;
                var recommendedMoviesLinks = [];

                recommendedMovies.each(function(jndex, jtem){
                    var recommendedRowObject = {};

                    var recommendedText = .text();

                    var recommendedLink = .attr("href");

                    recommendedRowObject["recommendedText"] = recommendedText
                    recommendedRowObject["recommendedLink"] = recommendedLink
                    recommendedMoviesLinks.push(recommendedLink);
                });

                Promise.mapSeries(recommendedMoviesLinks, function(url) {
                    return request.getAsync(url).spread(function(response,body) {
                        var $ = cheerio.load(body);
                        var obj = {};
                        //  GET SOME OTHER DESCRIPTION FROM THE RECOMMENDED MOVIE LINK

                        return obj;
                        });
                }).then(function(results) {
                    // results here returns an array of recommended movie links objects.
                }).catch(function(err) {
                });
                return main;
            });
        }).then(function(results) {
            // results here returns an array of movies

            //  I want to be able to link each movie with its recommended movies.
        }).catch(function(err) {
            console.log("Big Error " + err);
        });
    });
});

}

我的代码和背景的一些解释。

主页是一个有电影年的页面。我已经通过它们来获取这些年份的链接并放入一个数组movieYearLinks。

接下来,我使用Promise.mapSeries来获取有关电影的一些基本信息。在该基本信息中,表中列出了推荐的电影链接。我已经将它们循环并将它们放入一个数组中,推荐使用了MoriesLinks。

之后,我之前要去抓一些其他推荐的电影(recommendedMovieObject)信息。

我想创建一个包含所有这些信息的JSON对象。 JSON对象应该类似于

  

{movieYear:2017,movieLink:...,recommendedMovies(这是一个数组   of recommendedMovieObjects):}

我愿意接受任何解决方案来实现这一目标。提前谢谢。

1 个答案:

答案 0 :(得分:0)

你不需要嵌套承诺,承诺的全部要点就是不必嵌套回调。新的承诺需要被错误拒绝或者用值解决。你的代码应该是这样的:

let getMovieDetails = function(link){
   return new Promise(function(resolve,reject){
       request(link,function(err,response,body){
         err ? reject(err):resolve(body)
       }
   }).then(function(body){
     // do some cherio stuff
     return dataList
   }).then(function(dataList){
       return Promise.all(dataList.map(function(d){return // a promise of d}) 
   })
}

let finalData = getMovieDetails(link).then(function(data){ 
    //do some computation
}).catch(function(e){ // handle errors })

根据您的节点版本,根本不需要蓝鸟。 Javascript支持promises。