使用带有http请求的HighlandJS流

时间:2015-09-15 21:07:48

标签: node.js stream highland.js

我想获取一个网址数组并将其映射到每个网址的分页数组。

我想用溪流试试,但我不确定我明白自己在做什么。

我尝试了几件事,这是我降落的地方(不工作):

app.js

var getPageRank = require('pagerank');
var _ = require('highland');

var urls = [
    'google.com',
    'yahoo.com',
    'bing.com'
];

// Example usage of getPageRank
getPageRank(urls[0], function(err, ranking) {
    console.log(ranking);
});

var getPR = _.wrapCallback(getPageRank);

_(urls).map(getPR).toArray(function (myAnswer) {
    console.log(myAnswer);
});

的package.json

{
  "name": "page-rank",
  "version": "0.0.0",
  "description": "",
  "main": "app.js",
  "scripts": {
  },
  "author": "",
  "license": "ISC",
  "dependencies": {
    "highland": "^2.5.1",
    "pagerank": "^2.0.0"
  }
}

输出似乎是一个流数组,这看起来很奇怪来自toArray()和google的页面排名为9.我无法弄清楚如何包装getPageRank以便它等待返回回调中的值

1 个答案:

答案 0 :(得分:1)

由于您有流媒体流,因此您可以使用Stream.merge()Stream.flatten()将每个流的值合并为一个新流:

_(urls).map(getPR).merge().toArray(function (myAnswer) {
    console.log(myAnswer);
});