我目前正在使用Express框架学习NodeJS。出于某种原因,Express 4没有很多指南,但Express 3也没有。
我正在尝试使用connect-flash将错误从“注册”功能传递回Jade模板。
app.js
var express = require('express'),
session = require('express-session'),
path = require('path'),
favicon = require('serve-favicon'),
logger = require('morgan'),
cookieParser = require('cookie-parser'),
bodyParser = require('body-parser'),
flash = require('connect-flash');
var routes = require('./routes/index');
var app = express();
// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');
// uncomment after placing your favicon in /public
//app.use(favicon(__dirname + '/public/favicon.ico'));
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(session({secret: "testsecret", cookie: { maxAge: 60000 }}));
app.use(express.static(path.join(__dirname, 'public')));
app.use(flash());
app.use('/', routes);
// catch 404 and forward to error handler
app.use(function(req, res, next) {
var err = new Error('Not Found');
err.status = 404;
next(err);
});
// send errors to page if any.
app.use(function(req, res, next){
res.locals.success_messages = req.flash('success_messages');
res.locals.error_messages = req.flash('error_messages');
next();
});
// error handlers
// development error handler
// will print stacktrace
if (app.get('env') === 'development') {
app.locals.pretty = true;
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;
在我的routes.js中,我得到了这段代码:
router.post('/register', function(req, res) {
var params = req.body;
var email = params.email;
var username = params.username;
var password = params.password;
var error;
if(!validator.isEmail(email)) {
error = '<strong>' + email + '</strong> is not a valid email address!';
}
if(error.length > 0) {
req.flash('error', error);
res.redirect('/');
}
});
我100%确定存在错误,并req.flash('error', error);
通过。
我试图从我的index.jade访问此flash消息:
.alert.alert-danger #{messages.error}
但由于某种原因,我收到错误Cannot read property 'error' of undefined
。哪一个意味着messages
未定义。但是,我尝试使用error
以及error_messages
(请参阅app.js,第38行到第42行),但无济于事。
除了这个问题,我想知道你是否知道有什么好的资源可以找到明确的4个指南?
谢谢!
答案 0 :(得分:4)
我看到你正在使用中间件来访问所有视图中的消息。它非常好,但您必须在路线定义之前声明它:
// send errors to page if any.
app.use(function(req, res, next){
res.locals.success_messages = req.flash('success_messages');
res.locals.error_messages = req.flash('error_messages');
next();
});
app.use('/', routes);
并将错误名称更改为:
if(error.length > 0) {
req.flash('error_messages', error);
res.redirect('/');
}
Jade会自动转义您的html代码,因此您需要使用!{}
.alert.alert-danger !{error_messages}
如果您希望此特定错误消息不被视为“error_messages”,则可以更简单的方式执行此操作。
Jade:
-if(message)
.alert.alert-danger !{message}
服务器:
if(error.length > 0) {
req.flash('error', error);
res.redirect('/',{message: req.flash('error')});
}