0
0
mirror of https://github.com/honojs/hono.git synced 2024-11-22 11:17:33 +01:00
Web Framework built on Web Standards https://hono.dev/
Go to file
2022-09-14 08:17:20 +09:00
.github chore: add FUNDING.yml (#468) 2022-08-15 08:58:39 +09:00
.vscode refactor: automate import sorting (#157) 2022-04-20 14:17:55 +09:00
benchmarks feat: Lightweight RegExpRouter reborn (#519) 2022-09-14 08:01:14 +09:00
bun_test refactor(mime): made .ico file's extension to image/x-icon (#462) 2022-08-09 10:51:08 +09:00
deno_dist fix(types): add types to middleware correctly (#521) 2022-09-14 08:17:20 +09:00
deno_test refactor(mime): made .ico file's extension to image/x-icon (#462) 2022-08-09 10:51:08 +09:00
docs docs: update migration guide 2022-08-27 13:24:14 +09:00
src fix(types): add types to middleware correctly (#521) 2022-09-14 08:17:20 +09:00
.eslintignore
.eslintrc.js refactor: automate import sorting (#157) 2022-04-20 14:17:55 +09:00
.gitignore chore(git): ignore bun.lockb 2022-07-29 08:21:23 +09:00
.npmignore
.prettierrc chore(prettier): remove markdown-nocjsp parser 2022-07-16 10:03:01 +09:00
jest.config.js chore: absolute import to relative import (#228) 2022-05-14 12:55:01 +09:00
LICENSE
package.json feat(middleware): introduce "built-in" Validator Middleware (#505) 2022-09-13 07:54:06 +09:00
README.md docs(readme): update benchmark scores 2022-09-01 22:59:23 +09:00
tsconfig.build.esm.json fix: exclude src/middleware.ts 2022-07-15 08:40:15 +09:00
tsconfig.build.json fix: exclude src/middleware.ts 2022-07-15 08:40:15 +09:00
tsconfig.json refactor: enable strictPropertyInitialization (#333) 2022-07-01 10:30:43 +09:00
yarn.lock chore: bump up jest-environment-miniflare 2022-08-20 11:43:28 +09:00


Documentation 👉 honojs.dev
v2.x has been released! Migration guide


GitHub Workflow Status GitHub npm npm npm type definitions GitHub commit activity GitHub last commit Deno badge Discord badge

Hono - [炎] means flame🔥 in Japanese - is a small, simple, and ultrafast web framework for Cloudflare Workers, Deno, Bun, and others.

import { Hono } from 'hono'
const app = new Hono()

app.get('/', (c) => c.text('Hono!!'))

export default app

Features

  • Ultrafast - the router does not use linear loops.
  • Zero-dependencies - using only Service Worker and Web Standard API.
  • Middleware - built-in middleware, custom middleware, and third-party middleware.
  • TypeScript - first-class TypeScript support.
  • Multi-platform - works on Cloudflare Workers, Fastly Compute@Edge, Deno, or Bun.

Benchmarks

Hono is fastest, compared to other routers for Cloudflare Workers.

hono - trie-router(default) x 482,004 ops/sec ±5.00% (79 runs sampled)
hono - regexp-router x 604,006 ops/sec ±4.80% (81 runs sampled)
itty-router x 203,623 ops/sec ±2.10% (94 runs sampled)
sunder x 306,457 ops/sec ±2.49% (89 runs sampled)
worktop x 189,450 ops/sec ±3.14% (88 runs sampled)
Fastest is hono - regexp-router
✨  Done in 36.79s.

Documentation

The documentation is available on honojs.dev.

Migration

Migration guide is available on docs/MIGRATION.md.

Communication

Twitter and Discord channel are available.

Contributing

Contributions Welcome! You can contribute in the following ways.

  • Create an Issue - Propose a new feature. Report a bug.
  • Pull Request - Fix a bug and typo. Refactor the code.
  • Create third-party middleware - Instruct below.
  • Share - Share your thoughts on the Blog, Twitter, and others.
  • Make your application - Please try to use Hono.

For more details, see docs/CONTRIBUTING.md.

Contributors

Thanks to all contributors! Especially, @metrue and @usualoma!

Author

Yusuke Wada https://github.com/yusukebe

License

Distributed under the MIT License. See LICENSE for more information.