Express.js在后期行动中不会呈现

时间:2014-10-10 14:01:08

标签: node.js post express pug render

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")

1 个答案:

答案 0 :(得分:2)

我自己成功地解决了它! 我发现它发生了,因为我从客户端调用$.ajax的路由。 当我通过将此代码放入表单并删除$.ajax来更改调用方法时,它已完成。谢谢@mscdex

form(role="form" method="POST")

我将路线/contact/sendEmail更改为/contact