Node.js有点新,所以我几乎无法在互联网上找到东西。
我已经解决了这个问题。这是因为我使用$.ajax
从客户端打电话。
但是当我在下面的代码中尝试它时,它永远不会呈现。
初始页面是/ contact,当我调用/ contact / sendEmail时,/ contact / sendEmail中的所有函数都在工作,但不能用于渲染。
没有任何错误。这就像什么都没发生一样。
var Contact = require('../controllers/contact');
module.exports = function(app) {
app.get('/contact', function(req, res) {
res.render('contact');
});
app.post('/contact/sendEmail', function(req, res, next) {
var form = req.body;
Contact.validators.form(form, function(err) {
if (err) {
return res.render('user/register'); //This one never works!
/*return res.render('contact', {
error: err,
});*/
} else {
Contact.sendEmail(req, res, next);
}
});
});
};
由此函数调用
$('.contact').submit(function(event, done) {
var form = $(this);
var data = form.serializeArray();
// server side validation
// every contact form field is required
event.preventDefault();
$.ajax({
type: 'POST',
url: '/contact/sendEmail',
data: form.serialize()
})
.done(function(data) {
if (data.status == 'OK') {
$('#contact-success').modal('show');
} else {
return done('Please fill all of the fields.', false);
}
});
});
每个人都要学习。 我通过将其添加到jade文件中将其更改为从服务器端调用:
form(role="form" method="POST")
答案 0 :(得分:2)
我自己成功地解决了它!
我发现它发生了,因为我从客户端调用$.ajax
的路由。
当我通过将此代码放入表单并删除$.ajax
来更改调用方法时,它已完成。谢谢@mscdex
form(role="form" method="POST")
我将路线/contact/sendEmail
更改为/contact
。