【发布时间】:2018-07-06 22:32:15
【问题描述】:
我希望有人可以帮助通过 Handlebars 视图(使用引导标记)在 Express 中显示 Flash 消息。
在 app.js 中,我有以下模块和中间件来尝试让 flash 工作
//require modules
const express = require('express');
const cookieParser = require('cookie-parser');
const bodyParser = require('body-parser');
const expressValidator = require('express-validator');
const hbs = require('express-handlebars');
const session = require('express-session');
const flash = require('connect-flash');
const routes = require('./routes/index');
const app = express();
// view engine setup
app.engine('hbs', hbs({extname: 'hbs', defaultLayout: 'layout',layoutsDir: __dirname + '/views/layouts/'}));
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'hbs');
app.use(express.static(path.join(__dirname, 'public')));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));
app.use(expressValidator());
app.use(cookieParser());
app.use(session({
secret: process.env.SECRET,
key: process.env.KEY,
resave: false,
saveUninitialized: false,
store: new MongoStore({ mongooseConnection: mongoose.connection })
}));
app.use(flash());
app.use((req, res, next) => {
res.locals.h = helpers;
res.locals.flashes = req.flash();
res.locals.user = req.user || null;
res.locals.currentPath = req.path;
next();
});
app.use('/', routes);
module.exports = app;
还有一条路线
router.post('/store/add', storeController.createStore);
具有控制器功能
exports.createStore = async (req, res) => {
const store = new Store(req.body);
await store.save();
req.flash('error', 'leave a review');
console.log('my-messages',req.flash());
res.redirect('/');
};
当我创建新商店并被重定向到主页时,console.log 显示正确的值 my-messages { error: [ 'leave a review' ] },但我无法将其放入视图
我的主页('/')视图是
<h1>{{title}}</h1>
<p>Hi! Welcome to {{title}} </p>
<p>This page was built by {{created}}</p>
{{#if message}}
<div class="alert alert-danger">{{message}}</div>
{{/if}}
{{#if errors}}
{{#each errors}}
<div class="error">
{{msg}}
</div>
{{/each}}
{{/if}}
但什么也没有出现。我已经阅读了很多关于 SO 的类似问题,但似乎无法做到这一点。
非常感谢任何帮助。
【问题讨论】:
-
在控制器中尝试
res.locals.message = '...'。另外,您可能应该在询问之前尝试更多research。 -
感谢@marekful 我已经查看了该答案以及答案中提到的要点。我正在尝试使用
connect-flash,而不是gist.github.com/brianmacarthur/a4e3e0093d368aa8e423 中使用的express-flash,而另一个答案(以及要点gist.github.com/raddeus/11061808)不使用车把
标签: node.js express handlebars.js express-handlebars connect-flash