8

我是表达新手,我想探索 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();
});

另外,我jadepackage.json

4

5 回答 5

15

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

表达对电话的投诉,render因此您需要做的就是:

  1. 正确地评论视图(也正如Gerard Simpson提到的)
  2. 替换所有render调用:

res.render('error', {
        message: err.message,
        error: err
    });

res.status(500).json({
        message: err.message,
        error: err
    });
于 2016-04-21T15:12:45.207 回答
5

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

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

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

没有提供扩展

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

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

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

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

希望这可以帮助

于 2016-03-19T08:11:33.853 回答
1

你有两个选择:

  1. 使用模板引擎 Jade、ejs 等。并使用 res.render 含义渲染模板
  2. 仅使用静态文件和 api 调用,而不是仅调用 api 并使用从服务器返回的 json 在客户端呈现您的视图。res.send({users: [{id:1, name: 'adi'},{id:2, name: 'dave']});

如果您尝试将 express 用于 Apache 或 nginx 之类的东西,我认为您应该只使用https://github.com/yeoman/generator-webapp

于 2015-03-11T19:22:55.407 回答
0

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

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

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

类似于:

router.get('/', function(req, res, next) {
   res.send('index');
});
于 2018-04-16T09:02:23.780 回答
0

使用以下直接发送html文件

 res.sendFile('path/toFile')

您还可以查看有关该方法的详细信息的api 参考

线程还提到了一些替代方法,例如让 express 将您的 html 作为静态文件提供服务。

于 2016-03-02T11:02:37.620 回答