我有一个非常简单的代码,第一个console.log打印klout_user.id,但它从不打印第二个,即klout_response.score。 names是一组twitter屏幕名称。 由于控制流程,问题也可能如此。我尝试独立运行两个klout调用,它的工作原理。但它在以下代码中不起作用。任何线索?
names.forEach(function (name, i) {
klout.getKloutIdentity(name, function(error, klout_user) {
if (klout_user.hasOwnProperty("id") && klout_user.id > 0) {
console.log("klout user", name, "has id : ", klout_user.id);
klout.getUserScore(klout_user.id, function(error, klout_response) {
console.log("klout_user score : ", klout_response.score);
});
}
});
});
我的印象是,由于它打印了第一个console.log,因此也应该执行对getUserScore的调用。但事实并非如此。怎么了?
答案 0 :(得分:1)
我在node_klout github页面得到了Cojohn的答案。把它贴在这里作为答案。
您的代码未检索Klout用户分数,因为您依赖于for循环内的I / O绑定函数。基本上,您正在启动对Klout API的初始调用,该调用正常返回并打印到控制台,并且您的进程要么正在完成,要么函数在有机会执行klout.getUserScore()之前返回。下面是一个代码示例,它将在退出之前始终等待响应;请注意,我的测试黑客不是特别快或“异步”,它一次只处理一个用户,不适合大型用户列表。我的名字和api_key变量已被省略,你需要自己提供。
var klout = new Klout(api_key, "json", "v2");
var events = require("events");
var e = new events.EventEmitter();
e.on("done", function() {
process.exit();
});
e.on("next", function(i) {
if (i >= names.length) {
e.emit("done");
return;
}
console.log("retrieving kloutid for user %s", names[i]);
klout.getKloutIdentity(names[i], function(error, klout_user) {
if (error) {
console.log(error);
e.emit("next", i+1);
return;
}
if (!klout_user.hasOwnProperty("id") || klout_user.id <= 0) {
e.emit("next", i+1);
return;
}
console.log("klout user %s has id : %s", names[i], klout_user.id);
klout.getUserScore(klout_user.id, function(error, klout_response) {
if (error) {
console.log(error);
e.emit("next", i+1);
return;
}
console.log("klout_user score : %s", klout_response.score);
e.emit("next", i+1);
});
});
});
e.emit("next", 0);