我从 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 - 904
Error: 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/