我从 Express 为我生成的样板代码开始。我需要 dustjs-linkedin 并在 app.js 中编译一些简单的模板,如下所示:

var dust = require('dustjs-linkedin');...

app.set('view engine', 'dust');...

var compiled = dust.compile("Hello {name}!","intro");
// add into dust.cache manually
dust.loadSource(compiled);
console.log(dust.cache);

dust.render("intro", {name: "Fred"}, function(err, out) {
  if(err){console.log(err)}
  console.log(out);
});

这一切都很好,我在终端中看到了输出的 HTML。只有当我开始收到此错误时,才尝试从 route 执行相同的操作:
GET / 500 11.607 ms - 904Error: Cannot find module 'dust'
app.get('/', function(req, res){
  var compiled = dust.compile("Hello {name}!", "intro");
  dust.loadSource(compiled)
  dust.render("intro", {name: "Fred"}, function(err, out) {
    console.log(out);
    res.send(out);
    res.close();
  });
});

这一切都在 app.js 中,只有它在路由之外工作,但当我将它移动到路由回调中时就不行了。有谁知道为什么它找不到“灰尘”?我需要它,它应该在回调中可见,对吗?

谢谢你的帮助!

编辑 1
根据下面的评论,某处需要“灰尘”。我没有在我的代码中这样做;我的猜测是 Express 是在幕后进行的,因为我的模板以“.dust”文件结尾。我只是尝试删除我所有的模板(无论如何都没有使用它们),现在我收到了这个错误:
Error: Failed to lookup view "error" in views directory

我只想看到输出:“你好弗雷德”

编辑 2:我想我发现了什么问题

Interrobang 发布的所有内容都是正确的。我认为问题在于 express-generator 为我生成的这个中间件块:
app.use(function(req, res, next) {
  var err = new Error('Not Found');
  err.status = 404;
  next(err);
});

所以对于每个请求,这个中间件都会触发并抛出错误。我不是 100% 确定它在做什么,但如果我将其注释掉,一切正常。我现在的第二个问题,如果我可以有一个,究竟发生了什么,为什么它为所有请求设置?

最佳答案

您正在将 view engine 设置为 dust ,但是您还没有向 Express 注册引擎来告诉它如何渲染 Dust——并且 Express 在默认情况下不能这样做。

考虑使用 consolidate hoffman adaro (以及其他)作为 Express 的 Dust 渲染引擎。

这是一个使用 consolidate 的完整示例。我已经测试过,这适用于我的机器。

var express = require('express'),
    cons = require('consolidate'),
    app = express();

// assign the dust engine to .dust files
app.engine('dust', cons.dust);

// set .dust as the default extension
app.set('view engine', 'dust');
app.set('views', __dirname + '/views');

app.get('/', function(req, res) {
    res.render('index', { name: 'Interrobang' });
});

app.listen(3000, function () {
  console.log('Visit http://localhost:3000 woo!');
});

或者,只需从代码中删除 view engine 行。您没有使用 Express 进行渲染,因此 Express 甚至不需要知道。

这是一个非常简单的示例,没有我测试过的任何 View 引擎。您的 Dust 模板位于名为 views 的文件夹中。
var fs = require('fs'),
    path = require('path'),
    express = require('express'),

    dust = require('dustjs-helpers');

dust.config.whitespace = true;

dust.onLoad = function(tmpl, cb) {
  fs.readFile(path.join('./views', path.resolve('/', tmpl + '.dust')),
              { encoding: 'utf8' }, cb);
};

var app = express();
app.get('/', function (req, res) {
  dust.stream("hello", { "world": "World!" }).pipe(res);
});

app.listen(3000, function () {
  console.log('Visit http://localhost:3000 woo!');
});

关于node.js - 错误 : can't find 'dust' module when rendering dust templates on node. js,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/29189919/

10-09 14:46