" />

欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Express框架詳解app函數(shù)使用實例

 更新時間:2023年03月03日 09:54:02   作者:喬治_x  
這篇文章主要為大家介紹了Express框架app函數(shù)使用實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

express 函數(shù)來源

首先要搞明白 express 是一個函數(shù)。

express 函數(shù),函數(shù)也是個對象,意味著函數(shù)上也可以掛載自己的屬性。

module.exports = require("./lib/express");
exports = module.exports = createApplication;
function createApplication() {
  var app = function (req, res, next) {
    app.handle(req, res, next);
  };
  // ...
  return app;
}

此處省略中加的一些在這里無關的代碼,我們看到 express 函數(shù)其實是一個函數(shù),返回一個 app 函數(shù)。app 也很簡單 app 中調(diào)用了 app.handle 方法,注意這里 app.handle 其實用來接收請求的。這里會在請求數(shù)據(jù)的時候體驗到。現(xiàn)在目的是分析 app 函數(shù)的創(chuàng)建中會做哪些事情。

express 的其他輸出

exports.application = proto; // application 的原型
exports.request = req; // 請求對象
exports.response = res; // 響應對象
exports.Route = Route; // 路由項目
exports.Router = Router; // 路由
exports.json = bodyParser.json; //解析 json
exports.query = require("./middleware/query"); // 查詢
exports.raw = bodyParser.raw; // 生地址
exports.static = require("serve-static"); // 靜態(tài)地址
exports.text = bodyParser.text; // 文本
exports.urlencoded = bodyParser.urlencoded; // 解析

移除中間列表中包含了,使用錯誤提示:

var removedMiddlewares = [
  "bodyParser",
  "compress",
  "cookieSession",
  "session",
  "logger",
  "cookieParser",
  "favicon",
  "responseTime",
  "errorHandler",
  "timeout",
  "methodOverride",
  "vhost",
  "csrf",
  "directory",
  "limit",
  "multipart",
  "staticCache",
];
removedMiddlewares.forEach(function (name) {
  Object.defineProperty(exports, name, {
    get: function () {
      throw new Error(
        "Most middleware (like " +
          name +
          ") is no longer bundled with Express and must be installed separately. Please see https://github.com/senchalabs/connect#middleware."
      );
    },
    configurable: true,
  });
});

app 方法中混入原型

var mixin = require("merge-descriptors");
mixin(app, EventEmitter.prototype, false);
mixin(app, proto, false);
  • 混入 Node.js 的事件觸發(fā)
  • 混入 application 原型

app 中掛載請求/響應對象

var req = require("./request");
var res = require("./response");
app.request = Object.create(req, {
  app: { configurable: true, enumerable: true, writable: true, value: app },
});
app.response = Object.create(res, {
  app: { configurable: true, enumerable: true, writable: true, value: app },
});

從 req/res 對應的文件中,獲取 req/res 兩個不同對象。然后使用 Object.create 添加原型,然后創(chuàng)建了 value 是 app 的內(nèi)容。這個操作的作用是在 res/req 兩個對象中使用 app 函數(shù)以及掛載的對象。

app 中的原型

從源碼中得知,app 的 proto 并不是使用 app.prototype.xxx 來進行擴展的,而是使用 mixin 方法來進行擴展的。這里我們要了解到 JS 的原型鏈的安全問題(防止原型鏈被污染,這些重要的方法),下面?zhèn)z看看 merge-description 的實現(xiàn)方法:

"use strict";
module.exports = merge;
var hasOwnProperty = Object.prototype.hasOwnProperty;
function merge(dest, src, redefine) {
  // ...
  if (redefine === undefined) {
    redefine = true;
  }
  Object.getOwnPropertyNames(src).forEach(function forEachOwnPropertyName(
    name
  ) {
    if (!redefine && hasOwnProperty.call(dest, name)) {
      return;
    }
    var descriptor = Object.getOwnPropertyDescriptor(src, name);
    Object.defineProperty(dest, name, descriptor);
  });
  return dest;
}

多余的源碼已經(jīng)移除。本質(zhì)就是把 src 對象上自己的屬性描述符賦值給 dest 的屬性描述符,實現(xiàn)了此次 merge 或者叫做 mixin。

app 對象上掛載方法

注意 app 上的方法不是通過 prototype 的方式掛載的,在原密碼中被標記為 @private,是不被隨意修改的。

  • 定義 app 方法
var app = (exports = module.exports = {});
  • 方法和屬性說明
方法說明
defaultConfiguration初始化配置
lazyrouter(私有)如果沒有初始化過 router, 會初始化一次 router
handle(私有)將 req、res 對分派到應用程序中。開始管道處理。
use代理"Router#use()"將中間件添加到應用路由器
engine注冊模板引擎
param代理到"Router#param()",添加一個 api 功能。
set在 settings 對象設置一個 key-value
path返回一個 app 的絕對路徑
enabled檢查 settings 是否啟動
disabled檢查 settings 是否被禁用
enable設置 setting 是 true
disable設置 settings 是 false
app.[methods]按照 methods 中數(shù)組添加 app 上的 http 方法
all特殊情況的"all"方法,將給定的路由"路徑"、中間件和回調(diào)應用于_every_ HTTP 方法。
del是 delete 的別名
render渲染指定名字的模板
listen監(jiān)聽鏈接

app 初始化

app.init = function init() {
  this.cache = {};
  this.engines = {};
  this.settings = {};
  this.defaultConfiguration();
};

初始化方法很簡單,this 過載屬性

  • cache
  • engines
  • settings 配置

調(diào)用初始化配置,其實就是 settings 山掛載很多屬性:

  • 獲取環(huán)境變量
  • 啟動 x-powered-by
  • 設置 etag 是 weak
  • 設置環(huán)境變量
  • 設置 query parser
  • 設置 subdomain offset
  • 設置 trust proxy
  • 設置 this.settings trustProxyDefayultSymbol 的屬性
  • 添加 mount 監(jiān)聽函數(shù)
  • 配置 locals
  • 配置最好的 app 掛載到 /
  • 配置 local.settings 為 this.settings
  • 設置 view
  • 設置 views
  • 設置 jsonp callback name
  • 在生產(chǎn)環(huán)境中啟動 view cache
  • 在 router 上掛載 方法排除 app.router 被廢棄的放錯誤提示

這樣一個 app 就初始化完成了。

小結(jié)

這篇文章主要是對于 application 對象的內(nèi)容。首先有兩個 app 對象:

  • 第一個是函數(shù) app, 并且在 app 上掛載一些屬性,將來會合并 原型 app 對象
  • 第二個 app 就是第一個 app 的原型對象,為而立原型鏈的安全沒有使用 prootype 來實現(xiàn)方法,而是使用了私有方法來將倆個 app 進行合并。
  • 合并之后 app 初始上初始化了屬性和方法。例如常用的 use/[http#methods]/listen常用的屬性和方法。

以上就是Express框架詳解app函數(shù)使用實例的詳細內(nèi)容,更多關于Express框架app函數(shù)的資料請關注腳本之家其它相關文章!

相關文章

  • setTimeout時間設置為0詳細解析

    setTimeout時間設置為0詳細解析

    setTimeout( ) 是屬于 window 的 method, 但我們都是略去 window 這頂層容器名稱, 這是用來設定一個時間, 時間到了, 就會執(zhí)行一個指定的 method,下面這篇文章主要給大家介紹了關于setTimeout時間設置為0的相關資料,需要的朋友可以參考下。
    2018-03-03
  • json中換行符的處理方法示例介紹

    json中換行符的處理方法示例介紹

    json經(jīng)常使用,但如果字段中出現(xiàn)換行符如何處理,測試一下json類的處理,也沒有發(fā)現(xiàn)。想不到最終的處理確實如此簡單
    2014-06-06
  • Bootstrap圖片輪播組件使用實例解析

    Bootstrap圖片輪播組件使用實例解析

    圖片輪播組件是一個在網(wǎng)頁中很常見的技術,這篇文章主要為大家詳細介紹了Bootstrap圖片輪播組件使用實例,感興趣的小伙伴們可以參考一下
    2016-06-06
  • 深入解析ECMAScript?2023?中的新數(shù)組方法

    深入解析ECMAScript?2023?中的新數(shù)組方法

    ECMAScript?是一種標準化的腳本語言,它是?JavaScript?的規(guī)范。ECMAScript?2023?是?JavaScript?編程語言的更新,旨在帶來改進并使?JavaScript?程序可預測和可維護,這篇文章主要介紹了探索?ECMAScript?2023?中的新數(shù)組方法,需要的朋友可以參考下
    2023-12-12
  • 用最簡單的方法判斷JavaScript中this的指向(推薦)

    用最簡單的方法判斷JavaScript中this的指向(推薦)

    都說 JavaScript 是一種很靈活的語言,這其實也可以說它是一個混亂的語言,下面通過本文給大家分享JavaScript中this的指向知識,感興趣的朋友一起看看吧
    2017-09-09
  • javascript修改圖片src的方法

    javascript修改圖片src的方法

    這篇文章主要介紹了javascript修改圖片src的方法,通過簡單的圖片src獲取與賦值來實現(xiàn)修改src的功能,需要的朋友可以參考下
    2015-01-01
  • 利用CSS、JavaScript及Ajax實現(xiàn)圖片預加載的方法

    利用CSS、JavaScript及Ajax實現(xiàn)圖片預加載的方法

    預加載圖片是提高用戶體驗的一個很好方法,實現(xiàn)圖片預加載可以使用css、JavaScript、Ajax三種方法。下面逐一給大家介紹利用CSS、JavaScript及Ajax實現(xiàn)圖片預加載的方法,需要的朋友參考下吧
    2016-11-11
  • javascript實現(xiàn)根據(jù)漢字獲取簡拼

    javascript實現(xiàn)根據(jù)漢字獲取簡拼

    這里給大家分享一個JavaScript實現(xiàn)的根據(jù)漢字可以自動轉(zhuǎn)換簡拼代碼,有需要的朋友可以參考一下,并非本人原創(chuàng)來自網(wǎng)絡。
    2016-09-09
  • 完美實現(xiàn)八種js焦點輪播圖(上篇)

    完美實現(xiàn)八種js焦點輪播圖(上篇)

    這篇文章主要介紹了完美實現(xiàn)八種js焦點輪播圖的具體資料,基于完美運動框架move2.js而完成的八種焦點錄播圖,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-07-07
  • javascript中setTimeout的問題解決方法

    javascript中setTimeout的問題解決方法

    這篇文章主要介紹了javascript中setTimeout的問題以及對應的解決方法,需要的朋友可以參考下
    2014-05-05

最新評論