日韩欧美国产精品免费一二-日韩欧美国产精品亚洲二区-日韩欧美国产精品专区-日韩欧美国产另-日韩欧美国产免费看-日韩欧美国产免费看清风阁

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

Typescript中的通用中間件模式


2024年11月15日 21:35 本文熱度 1372

我實現的中間件模式與 Express、Koa 類似。基于一個 context 進行操作,并使用這個 context 作為參數按順序運行一系列中間件。另外還傳遞一個 next 函數。如果調用了這個 next 函數,列表中的下一個中間件將被調用;如果不調用,鏈將被中斷。此外,(與 Express 不同,但與 Koa 類似)中間件可以是 async 函數或返回一個 Promise。

準備工作

首先描述中間件:

/**
 * 傳遞給中間件的 'next' 函數
 */

type Next = () => void | Promise<void>;

/**
 * 一個中間件
 */

type Middleware<T> =
  (context: T, next: Next) => Promise<void> | void;

Middleware 是實際的異步/非異步中間件函數。我為 Next 定義了一個類型,這樣就不需要多次編寫它了。

如何使用它

假設我們有一個“應用程序”、一組中間件和一個我們想要操作的上下文。通過以下代碼表示:

/**
 * 應用程序的上下文類型。
 * 在 'koa' 中,這個對象將持有對 'request' 和 'response' 的引用,
 * 但我們的上下文只有一個屬性。
 */

type MyContext = {
  a: number;
}

/**
 * 創建應用程序對象
 */

const app = new MwDispatcher<MyContext>();

/**
 * 一個中間件
 */

app.use((context: MyContext, next: Next) => {

  context.a += 1;
  return next();

});

/**
 * 一個異步中間件
 */

app.use(async (context: MyContext, next: Next) => {

  // 等待 2 秒
  await new Promise(res => setTimeout(res, 2000));
  context.a += 2;
  return next();

});

運行這個應用程序

const context: MyContext = {
  a: 0,
}

await app.dispatch(context);
console.log(context.a); // 應該輸出 3

實現

實現這一切的代碼非常簡潔:

/**
 * 中間件容器和調用器
 */
 
class MwDispatcher<T> {

  middlewares: Middleware<T>[];

  constructor() {
    this.middlewares = [];
  }

  /**
   * 添加一個中間件函數。
   */

  use(...mw: Middleware<T>[]): void {

    this.middlewares.push(...mw);

  }

  /**
   * 在給定的上下文中按添加順序執行中間件鏈。
   */

  dispatch(context: T): Promise<void> {
     return invokeMiddlewares(context, this.middlewares)
  }

}

/**
 * 在上下文中調用中間件鏈的輔助函數。
 */

async function invokeMiddlewares<T>(context: T, middlewares: Middleware<T>[]): Promise<void{

  if (!middlewares.length) return;

  const mw = middlewares[0];

  return mw(context, async () => {
    await invokeMiddlewares(context, middlewares.slice(1));
  })

}

該文章在 2024/11/16 8:51:53 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved

主站蜘蛛池模板: 91直播在线观看免费 | 日韩精品不卡 | 国产网红主播 | 日韩欧美国产另 | 大地影院mv高清在线观看免费 | 老师脱了内裤让我进去 | 中文字幕在线视频观看网站 | 国产老妇玩伦国产熟女高清 | 欧美日韩中文在线 | 最新高清电影免费在线观看 | 欧美精品v | 日韩欧美亚洲一区二区综合 | 亚洲午夜国产片在线观看 | 国产精品精品 | 欧美激情性猛交 | 在线观看国产高清免费不卡黄 | 欧洲成人免费高清视频 | 亚洲精品在看在线观看 | 中文字幕日本αv一区二区 乱伦国产精品日本 | 精品第一国产久精国产宅男66 | 欧洲亚洲一区 | 国产中文字幕玖玖 | 免费人成在线观看vr网站 | 福利一区二区三区视频在线 | 青苹果乐园影院在线播放 | 欧美日韩第一区第138页 | 欧美精品视频一区 | 97国产综合色产在线视频 | 国产精品俺来也在 | 中文精品视 | 丰满岳乱妇在线观看中字无 | 国产嘿嘿嘿视频在线观看 | 写真福利理论片在线播放 | 三级在线观看免费观看电影 | 国产91蜜芽在线观看 | 香港三日本三级人妇三级99 | 国产精品偷伦视频观看免费 | 视频区国产图片区小说区 | 国产精品一卡二卡三卡四卡 | 91影视日韩欧美在线观看 | 最新精品亚洲成a人在线观看 |