極速輕量的 Web 框架 Hono,比 Express 小 40 倍!
Hono[1] 是一個極速、輕量且簡單的 Web 框架。它支持大量的 JavaScript 運行時:Cloudflare Workers、Fastly Compute、Deno、Bun、Vercel、Netlify、AWS Lambda、Lambda@Edge 和 Node.js。
Hono 的應用場景
Hono 是一個簡單的 Web 應用程序框架,類似於 Express,沒有前端。但它可以在 CDN 邊緣網絡上運行,與中間件結合後可以構建更大的應用程序。下面是一些應用場景。
-
構建 Web APIs
-
後端服務器代理
-
CDN 前端
-
邊緣應用程序
-
基礎服務器
-
全棧應用程序
基於 Hono 開發的應用程序,已經被成功運行在 Cloudflare Workers、Bun 和 Deno 等多種 JavaScript 運行時上。下圖展示了一些比較知名的應用程序:
Hono 的特性
-
超快🚀:路由器
RegExpRouter
非常快,不使用線性循環。 -
輕量級🪶:
hono/tiny
小於 14kB。Hono 零依賴,並且僅使用 Web 標準 API。 -
多運行時🌍:支持 Cloudflare Workers、Fastly Compute、Deno、Bun、AWS Lambda 或 Node.js。相同的代碼在所有平臺上運行。
-
功能齊全🔋:內置開箱即用的中間件、支持自定義中間件、第三方中間件和多種工具類。
-
友好的開發體驗😃:超簡潔的 API,支持 TypeScript。
速度超快
相比 Cloudflare Workers 上 itty-router、sunder 等其他路由組件,Hono 是最快的👍:
Hono x 402,820 ops/sec ±4.78% (80 runs sampled)
itty-router x 212,598 ops/sec ±3.11% (87 runs sampled)
sunder x 297,036 ops/sec ±4.76% (77 runs sampled)
worktop x 197,345 ops/sec ±2.40% (88 runs sampled)
Fastest is Hono
✨ Done in 28.06s.
輕量
Hono 非常小。在壓縮後,hono/tiny
的大小小於 14kB。提供了非常多常用的中間件和適配器,僅在使用時才進行打包。相比 Express 來說,它的尺寸是 572 kB。
$ npx wrangler dev --minify ./src/index.ts
⛅️ wrangler 2.20.0
--------------------
⬣ Listening at http://0.0.0.0:8787
- http://127.0.0.1:8787
- http://192.168.128.165:8787
Total Upload: 11.47 KiB / gzip: 4.34 KiB
支持多種路由
爲了滿足不同的使用情形,Hono 提供了多種路由組件:
-
RegExpRouter 是 JavaScript 世界中最快的路由器。它使用在調度之前創建的單個大型正則表達式來匹配路徑。藉助 SmartRouter,它支持所有路由模式。
-
LinearRouter 註冊路由的速度非常快,因此適用於每次都要初始化應用程序的環境。PatternRouter 只需添加和匹配模式,因此它的體積很小。
內置豐富的中間件和工具類
Hono 提供了豐富的中間件和工具類,讓 “Write Less, do more” 成爲現實。
使用 Hono 添加 ETag 和請求日誌只需幾行代碼:
import { Hono } from 'hono'
import { etag } from 'hono/etag'
import { logger } from 'hono/logger'
const app = new Hono()
app.use(etag(), logger())
友好的開發體驗
Hono 提供了友好的開發體驗。通過 Context
對象,可以輕鬆訪問請求 / 響應。此外,Hono 是用 TypeScript 編寫的,所以 Hono 擁有 “類型”。
有 TypeScript 類型系統的支持,路徑參數將被推斷爲字面量類型。
此外,Validator 和 Hono Client 支持 RPC 模式。在 RPC 模式下,你可以使用自己喜歡的 Validator(如 Zod),輕鬆地與客戶端共享服務器端 API 規範,並構建類型安全的應用程序。
快速開始
首先,使用 npm、yarn、pnpm、bun 或 deno 安裝 hono:
npm create hono@latest
yarn create hono
pnpm create hono
bunx create-hono
deno run -A npm:create-hono
然後,從 hono
包導入 Hono
類並創建 Hono 實例:
import { Hono } from 'hono'
const app = new Hono()
app.get('/', (c) => c.text('Hono!'))
export default app
Cloudflare 提供的 CLI 工具,也提供了最精簡的 honojs/hono-minimal
模板,讓開發者能夠基於 Hono 快速開發 Cloudflare Workers 應用程序:
npx wrangler generate my-app honojs/hono-minimal
Cloudflare Workers 的功能還是很強大的,基於它可以開發很多有用的小工具。感興趣的話,可以瀏覽 Github 上 awesome-cloudflare[2] 項目的內容。後續如果你也想開發 Cloudflare Workers、Fastly Compute 或 AWS Lambda 等 FaaS 應用,可以試試 Hono 這個輕量的開發框架。
參考資料
[1]
Hono: https://hono.dev/
[2]
awesome-cloudflare: https://github.com/zhuima/awesome-cloudflare
本文由 Readfog 進行 AMP 轉碼,版權歸原作者所有。
來源:https://mp.weixin.qq.com/s/4K1-i_pLHWMIbP34iKhYPg