如何禁用express 4中的jade / template引擎

时间:2014-08-12 14:36:12

标签: node.js express-4

我是新来表达的,我想探索Express的运作方式。

我使用的是最新版本的express 4 (4.8.1)

我不想使用任何模板引擎。我想手动提供我的HTML内容。

我该怎么做? 我在这里搜索了几个问题是StackOverflow,我找到了一个解决方案。 我应该做的就是评论以下几行。

// view engine setup
//app.set('views', path.join(__dirname, 'views'));
//app.set('view engine', 'jade');

但是当我这样做时,当我从浏览器点击服务器时出现以下错误。

Error: No default engine was specified and no extension was provided.
   at new View (/Users/adi/Desktop/srserver/node_modules/express/lib/view.js:41:42)
   at Function.app.render (/Users/adi/Desktop/srserver/node_modules/express/lib/application.js:499:12)
   at ServerResponse.res.render (/Users/adi/Desktop/srserver/node_modules/express/lib/response.js:955:7)
   at module.exports (/Users/adi/Desktop/srserver/app.js:50:9)
   at Layer.handle_error (/Users/adi/Desktop/srserver/node_modules/express/lib/router/layer.js:52:5)
   at trim_prefix (/Users/adi/Desktop/srserver/node_modules/express/lib/router/index.js:261:13)
   at /Users/adi/Desktop/srserver/node_modules/express/lib/router/index.js:230:9
   at Function.proto.process_params (/Users/adi/Desktop/srserver/node_modules/express/lib/router/index.js:305:12)
   at /Users/adi/Desktop/srserver/node_modules/express/lib/router/index.js:221:12
   at Function.match_layer (/Users/adi/Desktop/srserver/node_modules/express/lib/router/index.js:288:3)

这是整个代码。 (app.js)

var express = require('express');
var path = require('path');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');

var routes = require('./routes/index');
var users = require('./routes/users');

var app = express();

// view engine setup
//app.set('views', path.join(__dirname, 'views'));
//app.set('view engine', 'jade');

app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended:true}));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));

app.use('/', routes);
app.use('/users', users);

/// catch 404 and forward to error handler
app.use(function(req, res, next) {
    var err = new Error('Not Found');
    err.status = 404;
    next(err);
});

/// error handlers

// development error handler
// will print stacktrace
if (app.get('env') === 'development') {
    app.use(function(err, req, res, next) {
        res.status(err.status || 500);
        res.render('error', {
            message: err.message,
            error: err
        });
    });
}

// production error handler
// no stacktraces leaked to user
app.use(function(err, req, res, next) {
    res.status(err.status || 500);
    res.render('error', {
        message: err.message,
        error: {}
    });
});

module.exports = app;

app.listen(3000,function(){
    console.log("Listening on #3000");
});

app.get("/",function(req,res){
    response.writeHead(200, {'Content-Type': 'text/plain'});
    response.write('Simple Simple Fun')
    response.end();
});

另外,我从jade

中删除了package.json

5 个答案:

答案 0 :(得分:8)

上面的答案中缺少一件事。

表达对render来电的投诉,所以您需要做的就是:

  1. 正确评论视图(同时提及Gerard Simpson
  2. 替换所有render来电:
  3. res.render('error', {
            message: err.message,
            error: err
        });
    

    res.status(500).json({
            message: err.message,
            error: err
        });
    

答案 1 :(得分:3)

注释掉这段代码是正确的:

// view engine setup
//app.set('views', path.join(__dirname, 'views'));
//app.set('view engine', 'jade');

您收到此错误的原因是您没有在./public目录中提供带有文件扩展名的文件。该错误的第二部分说:

  

未提供任何扩展

快速4服务器到服务器静态html文件所需的唯一代码是:

app.use(express.static(path.join(__dirname, 'public')));

告诉您的快速服务器查看您的./public目录以提供静态文件。

如果您添加./public/index.html,则可以将其作为静态文件提供。

希望这有帮助

答案 2 :(得分:1)

您有两种选择:

  1. 使用模板引擎Jade,ejs等。 并使用res.render意义渲染模板
  2. 仅使用静态文件和api调用,而不是只调用api并使用从服务器返回的json在客户端呈现视图。 res.send({users:[{id:1,name:'adi'},{id:2,name:'dave']});
  3. 如果您尝试使用express来代替Apache或nginx,我认为您应该使用https://github.com/yeoman/generator-webapp

答案 3 :(得分:0)

Use the following to send the html file directly

 res.sendFile('path/toFile')

You might also take a look at the api reference for Details about the method.

This thread also mentions some alternatives like letting express serve your html as static files.

答案 4 :(得分:0)

我知道这是一个老问题,但我收到了一些错误。

您需要更改@Kfir Erez所说的内容,并更改您的routes / index.js中的响应:

boundsMode

类似于:

router.get('/', function(req, res, next) {
   res.render('index', { title: 'Express' });
});