Koa是一個新的
web
框架,由 Express 幕後的原班人馬打造, 致力於成爲web
應用和API
開發領域中的一個更小、更富有表現力、更健壯的基石。 經過利用async
函數,Koa
幫你丟棄回調函數,並有力地加強錯誤處理。Koa
並無捆綁任何中間件
, 而是提供了一套優雅的方法,幫助您快速而愉快地編寫服務端應用程序。css
筆者對這幾個框架都不熟,這裏就不誤人子弟了。能夠看看下面一些大佬的介紹。html
Koa
是由Express
的原班人馬打造,那麼他們爲何不將Express
升級版本呢而是重新開發新的一個項目?看官方的介紹:Koa 與 Expressnode
中間件(英語:
Middleware
),又譯中間件、中介層,是提供系統軟件和應用軟件之間鏈接的軟件,以便於軟件各部件之間的溝通,特別是應用軟件對於系統軟件的集中的邏輯,在現代信息技術應用框架如Web
服務、面向服務的體系結構等中應用比較普遍。中間件-維基百科git
中間件只是一種服務,沒有這種服務系統也可以存在。好比:一臺臺式機,是由不少個部件組裝而成。鼠標、鍵盤等只是爲了讓系統更加完善。即便沒有鼠標或者鍵盤,臺式機也可使用其餘硬件軟件來操做電腦。或者查看 AOP 面向切面編程 中的比喻。github
Koa
是一箇中間件框架,能夠採用兩種不一樣的方法來實現中間件:express
async function
common function
如下是使用兩種不一樣方法實現一個日誌中間件的示例:編程
中間件一般帶有兩個參數
(ctx, next), ctx
是一個請求的上下文(context)
,
next
是調用執行下游中間件的函數. 在代碼執行完成後經過then
方法返回一個Promise
。關於Promise
介紹能夠查看這篇文章: Promise原理講解 && 實現一個Promise對象 (遵循Promise/A+規範)設計模式
async functions (node v7.6+)瀏覽器
app.use(async (ctx, next) => { const start = Date.now(); await next(); const ms = Date.now() - start; console.log(`${ctx.method} ${ctx.url} - ${ms}ms`); });
Common function
app.use((ctx, next) => { const start = Date.now(); return next().then(() => { const ms = Date.now() - start; console.log(`${ctx.method} ${ctx.url} - ${ms}ms`); }); });
Koa
的中間件機制使用的是洋蔥模型
,而什麼是洋蔥模型呢?
經過
next()
把多箇中間件串聯執行的效果。全部的中間件都會執行兩邊,就像洋蔥同樣,從洋蔥的一側進入就會從另外一側出去。
洋蔥圈模型圖示1來源
就是從請求到響應的過程全部的中間件都會走兩遍。看不太清楚的能夠看圖示2。
洋蔥圈模型圖示2 來源
經過圖示可能還不是很清楚Koa
洋蔥模型的執行過程,下面來看一個簡單例子:
const Koa = require('koa'); const app = new Koa(); // 中間件1 app.use(async (ctx, next)=>{ console.log(1) next() console.log(11) }); // 中間件2 app.use(async (ctx, next) => { console.log(2) next() console.log(22) }) // 中間件3 app.use(async (ctx, next) => { console.log(3) next() console.log(33) }) app.listen('3000'); console.log(`http://localhost:3000`);
在瀏覽器輸入http://localhost:3000
回車以後的輸出結果:
http://localhost:3000 1 2 3 33 22 11
經過結果能夠看出執行過程和洋蔥模型是一致的。
諮詢請加微信:輕撩便可。