Вопрос

Итак, только «Res.Render» только тогда, когда вы уверены, что все закончилось, верно? Потому что это заканчивает запрос и вынимает веб -страницу.

Это было полезно?

Решение

Если вы не предоставите обратный вызов res.render(view[, options[, fn]]) Он автоматически даст ответ с 200 HTTP Status и Content-Type: Text/HTML

res.render('view', {}, function() {
    while (true); // should block 
});

res.render (view [, options [, fn]])

Рендеринг представления с данными параметрами и необязательным обратным вызовом Fn. Когда функция обратного вызова дана ответ не будет выполнен автоматически, однако в противном случае дается ответ 200 и текст/HTML.

Express.js Guide

Другие советы

С током Github Master Commit, Это res.render в lib/view.js:

 /**
 * Render `view` with the given `options` and optional callback `fn`.
 * When a callback function is given a response will _not_ be made
 * automatically, however otherwise a response of _200_ and _text/html_ is given.
 *
 * Options:
 *  
 *  - `scope`     Template evaluation context (the value of `this`)
 *  - `debug`     Output debugging information
 *  - `status`    Response status code
 *
 * @param  {String} view
 * @param  {Object|Function} options or callback function
 * @param  {Function} fn
 * @api public
 */
res.render = function(view, opts, fn, parent, sub){
  // support callback function as second arg
  if ('function' == typeof opts) {
    fn = opts, opts = null;
  }

  try {
    return this._render(view, opts, fn, parent, sub);
  } catch (err) {
    // callback given
    if (fn) {
      fn(err);
    // unwind to root call to prevent
    // several next(err) calls
    } else if (sub) {
      throw err;
    // root template, next(err)
    } else {
      this.req.next(err);
    }
  }
};
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top