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")
最佳答案
我自己成功解决了!
我发现发生这种情况是因为我从客户端调用 $.ajax
的路由。
当我通过将此代码放入表单并删除 $.ajax
来更改调用方法时,就完成了。谢谢@mscdex
form(role="form" method="POST")
我将路由 /contact/sendEmail
更改为 /contact
。
关于node.js - Express.js 不会在后期操作中呈现,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26301254/