node_klout node.js:getKloutIdentity后跟getUserScore无法正常工作

时间:2013-07-22 13:22:38

标签: node.js control-flow klout

我有一个非常简单的代码,第一个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的调用。但事实并非如此。怎么了?

1 个答案:

答案 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);