在下面的代码中,我们有一个单一的视图,即。fruitPicker.html
所以关于 bodyParser 应该如何填充没有歧义req.body
应用程序.js:
var express = require('express')
, app = express()
, cons = require('consolidate');
app.engine('html', cons.swig);
app.set('view engine', 'html');
app.set('views', __dirname + '/views');
app.use(express.bodyParser());
app.use(app.router);
// Handler for internal server errors
function errorHandler(err, req, res, next) {
console.error(err.message);
console.error(err.stack);
res.status(500);
res.render('error_template', {error: err});
}
app.use(errorHandler);
app.get('/', function(req, res, next) {
res.render('fruitPicker', {
'fruits' : ['apple', 'orange', 'banana', 'peach']
});
});
app.post('/favorite_fruit', function(req,res,next) {
var favorite = req.body.fruit;
if (typeof favorite == 'undefined') {
next(Error('Please choose a fruit!'));
}
else {
res.send("Your favorite fruit is " + favorite);
}
});
app.listen(3030);
console.log('Express server listening on port 3030');
水果选择器.html:
<html>
<head><title>Fruit Picker</title></head>
<body>
<form action="/favorite_fruit" method="POST">
<p>What is your favorite fruit?</p>
{% for fruit in fruits %}
<p>
<input type="radio" name="fruit" value="{{fruit}}">{{fruit}}</input>
</p>
{% endfor %}
<input type="submit" value="Submit" />
</form>
</body>
</html>
<!doctype HTML>
如果我们有几个视图,比如说fruitPicker.html
anddrinksPicker.html
怎么办?我想然后会从我们来自的当前最新视图中bodyParser
填充,对吗?req.body
然后,我们如何传达此信息,app.post
以便帖子可以根据每个返回不同的响应(您最喜欢的水果是......或您最喜欢的饮料是......)?我们只有一个req.body
不区分水果和饮料的通用变量,所以怎么app.post
知道?是否只能由我们为单选框命名不同的名称并分配req.body.fruit
或req.body.drink
最喜欢?这似乎不是很健壮,因为我们可能会在某些情况下无意中为输入单选框使用相同的名称(它们毕竟位于不同的文件中)并且可能会进行硬调试,不是吗?如果 bodyParser 构建在它来自的回溯路径中会更好,不是吗?