Node.js回调混乱

时间:2012-01-02 18:24:10

标签: javascript node.js asynchronous callback nowjs-sockets

我正在尝试使用nowjs在nodejs应用上实现自动完成。

everyone.now.sendAutocomplete = function(search) {  
  var response = getAutocomplete(search);
  console.log("response");
  console.log(response);
};

调用:

function getAutocomplete(search) {
    console.log(search);
    var artist = new Array();

    request({uri: 'http://musicbrainz.org/ws/2/artist/?query=' + search + '&limit=4', headers: "Musicbrainz Application Version 1"}, function(error, response, body) {
        par.parseString(body, function(err, result) {
            var count = result['artist-list']['@']['count'];

            var artists = result['artist-list']['artist'];
            // var artist = new Array();

            if (count > 1) {
            artists.forEach(function(a) {
                var att = a['@'];
                var id = att['id'];
                var name = a['name'];
                var dis = a['disambiguation'];

                if (dis) {
                    var display = name + " (" + dis + " )";
                } else {
                    display = name;
                }
                artist.push({'id':id, 'name': name, 'disambiguation':dis,
                                     'label':display, 'value':name, 'category':"Artists"});
            });
            //everyone.now.receiveResponse(artist);
            console.log("artist");
            console.log(artist);
            return artist;
        } else {
            console.log(artists);
            var att = artists['@'];
            var id = att['id'];
            var name = artists['name'];
            var dis = artists['disambiguation'];
            var resp = [{'id':id, 'name': name, 'disambiguation':dis,
                                 'label':name, 'value':name, 'category':"Artists"}];
            return resp;
            // everyone.now.receiveResponse([{'id':id, 'name': name, 'disambiguation':dis,
            //                       'label':name, 'value':name, 'category':"Artists"}]);
        }

        });
    });
}

但是,console.log(响应)表示响应未定义。我是节点的新手,所以答案可能很简单,但仍然无法弄清楚。

1 个答案:

答案 0 :(得分:6)

您将异步调用视为同步。您的getAutocomplete需要使用回调函数来获取响应。您已经在request来电和parseString来电中使用了很多内容。

像这样:

everyone.now.sendAutocomplete = function(search) {  
    getAutocomplete(search, function (response) {
        console.log("response");
        console.log(response);
    });
};

而不是return

function getAutocomplete(search, callback) {
    // ...
    callback(result);
    // ...
}