0
0
mirror of https://github.com/honojs/hono.git synced 2024-12-01 11:51:01 +01:00
hono/deno_dist
Yusuke Wada 05ee837f78
feat: change the arg InferResponseType receives (#893)
* feat: change the arg `InferResponseType` receives

* denoify
2023-02-15 07:05:39 +09:00
..
adapter/deno fix(deno): export deno adapter (#886) 2023-02-12 16:35:22 +09:00
client feat: change the arg InferResponseType receives (#893) 2023-02-15 07:05:39 +09:00
middleware fix(req): query return type as string | undefined (#888) 2023-02-13 21:40:51 +09:00
router feat(router) [breaking]: StaticRouter obsolete (#873) 2023-02-09 16:58:28 +09:00
utils fix(req): query return type as string | undefined (#888) 2023-02-13 21:40:51 +09:00
validator refactor: rename ValidationTypes to ValidationTargets (#890) 2023-02-14 06:21:30 +09:00
compose.ts merge main into next 2023-02-09 19:49:27 +09:00
context.ts refactor: rename to TypedResponse (#889) 2023-02-13 21:57:12 +09:00
hono.ts refactor: rename to TypedResponse (#889) 2023-02-13 21:57:12 +09:00
http-exception.ts feat: move http-exception out of utils (#883) 2023-02-11 18:05:50 +09:00
LICENSE chore: update license, contributors as the copyright holders (#769) 2023-01-02 19:18:59 +09:00
middleware.ts feat(validator): moved validator outside of middleware (#879) 2023-02-11 01:18:27 +09:00
mod.ts refactor: rename ValidationTypes to ValidationTargets (#890) 2023-02-14 06:21:30 +09:00
README.md docs(readme): add bundlephobia badges (#891) 2023-02-14 22:50:58 +09:00
request.ts refactor: rename ValidationTypes to ValidationTargets (#890) 2023-02-14 06:21:30 +09:00
router.ts Introduce StaticRouter and SmartRouter (#501) 2022-09-12 20:49:18 +09:00
types.ts refactor: rename ValidationTypes to ValidationTargets (#890) 2023-02-14 06:21:30 +09:00


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


GitHub Workflow Status GitHub npm npm Bundle Size Bundle Size 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 routers are really smart. Not using linear loops. The fastest one will be selected from three routers.
  • Zero-dependencies - Using only Web Standard API. Does not depend on other npm or Deno libraries.
  • Middleware - Hono has built-in middleware, custom middleware, and third-party middleware. Batteries included.
  • TypeScript - First-class TypeScript support. Now, we've got "Types".
  • Multi-runtime - Works on Cloudflare Workers, Fastly Compute@Edge, Deno, Bun, or Node.js. The same code runs on all platforms.

Benchmarks

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

Hono x 385,807 ops/sec ±5.02% (76 runs sampled)
itty-router x 205,318 ops/sec ±3.63% (84 runs sampled)
sunder x 287,198 ops/sec ±4.90% (74 runs sampled)
worktop x 191,134 ops/sec ±3.06% (85 runs sampled)
Fastest is Hono
✨  Done in 27.51s.

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.