为什么我的节点事件回调在事件中显示为未定义?

时间:2015-05-24 00:55:12

标签: javascript node.js url javascript-events

我正在尝试将url字符串作为“data”传回我的eventhandler。

我对服务器的请求是“https://172.20.10.6/index.html”。 下面的console.log按照我的预期打印出“/index.html”。

switch(req.method) {
    case 'GET':

    console.log("logged from plugin-https.js: url: " + req.url);

     ee.emit("dataIn", req.url);

     break;

以下是eventHandler代码 console.log(data);评估为“未定义”。我想弄清楚为什么会这样。这似乎是一个非常简单的直接回调,所以我想知道为什么数据在事件处理代码中显示时没有定义。

     plugin = rtrn;
         console.log('4');
         plugin.dataIn(config, function(err, data) {
           if(err, data) {

             console.log('error geting data');
           } else {
            // This is where request events are being handled.  
            console.log(data);



            console.log('We are in the event handling codeblock of funtion startRuntime() located in interactor.js');

此外,这是我的回调代码

var ee = new events.EventEmitter();

function dataIn(config, callback) {
 if(typeof callback === 'function') {

   ee.on("dataIn", callback);

1 个答案:

答案 0 :(得分:1)

看起来你正在吞咽错误。

if(err, data) {
    console.log('error geting data');
}

该条件(err, data)将忽略err的值。如果data未定义,那将是假的,你不会知道你有错误。你可能想要更像这样的东西:

if (err) {
    console.log('error getting data')
}

追溯到您的发射器,您的发射方式是将数据发送到第一个参数,该参数应该是错误发生的位置。所以这个:

ee.emit("dataIn", req.url);

......应该更像这样:

ee.emit("dataIn", null, req.url);