Node.js + Actionhero代码没有连续运行

时间:2014-12-04 09:31:26

标签: javascript node.js actionhero

我显然错过了关于Node.js和Actionhero如何工作的非常重要的事情。

有人可以向我解释为什么会出现以下问题:

我有这个简单的代码: 基本上它读取.css文件。

buildAdsHTML: function (ads, type) {
        var cssDir = path.normalize(__dirname + '/../public/css/');
        switch (type) {
            case  'text':
                var result = '';
                console.log("STEP 1");
                fs.readFile(cssDir + type + 'Ads.css', {encoding: 'utf8'}, function (err, data) {

                    console.log(err);
                    console.log(data);
                    if (!err) {

                        console.log("STEP 2");
                        result += '<style>' + data + '</style>';

                    } else {

                    }
                });

                break;

        }
        console.log('STEP 3');
        return result;
    }

现在运行此代码时,我得到一个空字符串作为结果。控制台输出如下:

STEP 1 <- so far so good 
STEP 3<- this should be last!

null <- this is the error variable 

.some-random-css-class{
    display: block;
    width: 100;
    min-height: 250px;
}

STEP 2

现在在某些时候我发现fs.reafFile是异步函数。 所以我自然地将其更改为同步版本fs.readFileSync。 现在控制台输出更糟糕了:

STEP 1
STEP 3

多数民众赞成!没有其他的。 结果我仍然得到一个空字符串。 就像整个代码甚至不通过swich

我在动作项目的所有功能和方法中都注意到了这种行为, 最值得注意的是,在致电next(connection)时。你不能在方法结束时调用它。

ifswich 我必须在里面调用它才能对结果进行任何实际控制。

否则,我添加到连接中的每个新数据都将丢失。

那是什么?请详细解释该功能,以免在编码时出现任何dumn错误。

2 个答案:

答案 0 :(得分:0)

最终想通了。

问题是我没有注意到fs.readFileSync没有回调功能。

因此该功能的正确使用应该是

var result= fs.readFileSync(pathToFile,{options})
return result;

我仍然可以对next(connection);提到的问题使用一些帮助。我不知道为什么它会像这样跳过整个代码部分。

答案 1 :(得分:0)

如果你传递任何参数,我发现next()不喜欢它。我的申请中有一个错误,因为我正在做'。然后(下一个);'