3

我似乎没有让 JSHTML 在 Node.js 中的 Express.js 上作为模板引擎工作。当我安装我的 Express.js 应用程序并为我创建了一个基本应用程序并运行它时,我收到以下错误消息:

500 TypeError: Property 'engine' of object #<View> is not a function
at View.render (/Users/blackbook/nodejs/ds/node_modules/express/lib/view.js:75:8)
at Function.app.render (/Users/blackbook/nodejs/ds/node_modules/express/lib/application.js:504:10)
at ServerResponse.res.render (/Users/blackbook/nodejs/ds/node_modules/express/lib/response.js:677:7)
at exports.index (/Users/blackbook/nodejs/ds/routes/index.js:7:7)
at callbacks (/Users/blackbook/nodejs/ds/node_modules/express/lib/router/index.js:165:11)
at param (/Users/blackbook/nodejs/ds/node_modules/express/lib/router/index.js:139:11)
at pass (/Users/blackbook/nodejs/ds/node_modules/express/lib/router/index.js:146:5)
at Router._dispatch (/Users/blackbook/nodejs/ds/node_modules/express/lib/router/index.js:173:5)
at Object.router (/Users/blackbook/nodejs/ds/node_modules/express/lib/router/index.js:33:10)
at next (/Users/blackbook/nodejs/ds/node_modules/express/node_modules/connect/lib/proto.js:190:15)

我的 app.js 看起来像这样(这是 Express.js 为我创建的):

/**
 * Module dependencies.
 */

var express = require('express')
  , routes = require('./routes')
  , http = require('http')
  , path = require('path');

var app = express();

app.configure(function(){
  app.set('port', process.env.PORT || 3000);
  app.set('views', __dirname + '/views');
  app.set('view engine', 'jshtml');
  app.use(express.favicon());
  app.use(express.logger('dev'));
  app.use(express.bodyParser());
  app.use(express.methodOverride());
  app.use(app.router);
  app.use(express.static(path.join(__dirname, 'public')));
});

app.configure('development', function(){
  app.use(express.errorHandler());
});

app.get('/', routes.index);

http.createServer(app).listen(app.get('port'), function(){
  console.log("Express server listening on port " + app.get('port'));
});

我有这个安装:

  • Node.js v.0.8.5
  • Express.js@3.0.0rc2
  • jshtml@0.2.3
4

5 回答 5

3

JSHTML 目前与 Express.js 2 一起使用。计划让引擎与 Express.js 3 一起使用,但目前我忙于享受夏天!期待在冬天解决这个问题!

于 2012-08-14T07:48:55.510 回答
2

根据https://github.com/visionmedia/express/wiki/Migrating-from-2.x-to-3.x您可以使用 app.engine 来实现 2-x 兼容性。

例如

var fs = require("fs");
var jshtml = require("jshtml");
app.engine("jshtml", function (path, options, fn) {
    fs.readFile(path, 'utf8', function (err, str) {
        if (err) return fn(err);
        str = jshtml.compile(str,options)(options).toString();
        fn(null, str);
    });
});
于 2013-01-13T14:45:29.413 回答
0

consolidate.js 被用作许多模板引擎和 express 之间的桥梁。如果您的引擎不受支持,请查看源代码。大多数引擎需要大约 15 行代码来实现。

于 2012-08-09T15:06:47.087 回答
0

我让它在我的项目中工作,可能很快就会发出拉取请求,但现在看看我在 https://github.com/elmerbulthuis/jshtml/issues/5中的评论

于 2013-01-13T20:21:57.723 回答
0

试试下面的。它对我有用,就像你一样。

首先,通过 npm 安装 jshtml-express,然后执行以下操作。

var app = express();
**app.engine('jshtml', require('jshtml-express'));**

// All environments
app.set('port', process.env.PORT || 3000);
app.set('views', __dirname + '/views');
app.set('view engine', 'jshtml');
app.use(express.favicon());
app.use(express.logger('dev'));
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(app.router);
app.use(express.static(path.join(__dirname, 'public')));

我希望它也对你有用。

于 2014-06-17T04:44:23.903 回答