nodejs express 框架解密3-中間件模塊

本文檔是基於express 3.4.6 的express

在上篇中咱們提到了中間件,這篇主要解釋這個模塊,middleware.js 爲:api

var utils = require('./utils');

/**
 * Initialization middleware, exposing the
 * request and response to eachother, as well
 * as defaulting the X-Powered-By header field.
 *
 * @param {Function} app
 * @return {Function}
 * @api private
 */

exports.init = function(app){
  return function expressInit(req, res, next){
    if (app.enabled('x-powered-by')) res.setHeader('X-Powered-By', 'Express');
    //將req,res,next 從新封裝下
    req.res = res;
    res.req = req;
    req.next = next;

    //將req,res的原型設置爲connect的request,response 對象
    req.__proto__ = app.request;
    res.__proto__ = app.response;

    res.locals = res.locals || utils.locals(res);

    next();
  }
};

咱們看到這個函數返回一個function,他將咱們的app(connect建立的) request ,response 做爲了 req,res 的原型對象了。爲模板的渲染,直接調用。app

那app.request,app.response 是什麼呢?函數

咱們看看在express.js中ui

function createApplication() {
  var app = connect();
  //將application中的方法所有拷貝到connect對象上去。
  utils.merge(app, proto);
  //設置app 的request對象的原型爲req,自己的屬性爲connect對象
  app.request = { __proto__: req, app: app };
  //設置app的response對象原型爲res ,自己的屬性爲connect對象
  app.response = { __proto__: res, app: app };
  //調用application中的方法init
  app.init();
  return app;
}

app.request,app.response 的原型是req,res,他們分別是request.js 封裝的請求處理對象, response.js 封裝響應處理對象。spa

這就方便後面的視圖模板渲染了。code

相關文章
相關標籤/搜索