0
0
mirror of https://github.com/honojs/hono.git synced 2024-12-01 11:51:01 +01:00
Web Framework built on Web Standards https://hono.dev/
Go to file
Yusuke Wada b3868d1075
fix(types): app.route with multiple endpoints returns types correctly (#919)
* fix(types): `app.route` with multiple endpoints returns types correctly

* fix `OnHandlerInterface` patterns too.

* denoify

* fix type mismatch of Env

* remove unnecessary assert
2023-02-24 09:07:25 +09:00
.github ci: run ci on next branch 2023-01-19 22:45:25 +09:00
.vscode feat(validator): add support for JSON array path validation (#563) 2022-09-30 21:56:39 +09:00
benchmarks chore: update Deno benchmark (#880) 2023-02-11 06:43:07 +09:00
deno_dist fix(types): app.route with multiple endpoints returns types correctly (#919) 2023-02-24 09:07:25 +09:00
docs docs(migration): add descriptions (#904) 2023-02-18 21:36:35 +09:00
src fix(types): app.route with multiple endpoints returns types correctly (#919) 2023-02-24 09:07:25 +09:00
test_bun feat: [BREAKING] introduce adapters (#807) 2023-01-19 22:45:25 +09:00
test_deno fix(req): query return type as string | undefined (#888) 2023-02-13 21:40:51 +09:00
test_fastly ci: refine CI structures (#784) 2023-01-19 22:44:38 +09:00
test_lagon feat: move http-exception out of utils (#883) 2023-02-11 18:05:50 +09:00
test_node test: add tests and CI for Node.js (#785) 2023-01-19 22:45:23 +09:00
.eslintignore
.eslintrc.cjs refactor(validator): show type error if get/head with form/json (#772) 2023-01-19 22:44:38 +09:00
.gitignore chore(git): ignore bun.lockb 2022-07-29 08:21:23 +09:00
.prettierrc chore(prettier): remove markdown-nocjsp parser 2022-07-16 10:03:01 +09:00
build.ts fix(build): fix ESM support in Node.js / use esbuild (#631) 2022-10-28 08:46:02 +09:00
jest.config.js chore: remove unnecessary config testPathIgnorePatterns (#697) 2022-12-02 02:18:00 +09:00
jest.fastly.config.js ci: refine CI structures (#784) 2023-01-19 22:44:38 +09:00
jest.node.config.js test: add tests and CI for Node.js (#785) 2023-01-19 22:45:23 +09:00
LICENSE chore: update license, contributors as the copyright holders (#769) 2023-01-02 19:18:59 +09:00
package.cjs.json fix(typo): package.cjs.json target to type (#634) 2022-10-29 16:09:32 +09:00
package.json v3.0.1 2023-02-20 19:53:09 +09:00
README.md docs(readme): add "quick start" 2023-02-23 05:49:16 +09:00
tsconfig.build.json fix package.json & tsconfig.build.json (#747) 2022-12-27 22:59:23 +09:00
tsconfig.json remove unnecessary individual strict mode family options (#805) 2023-01-16 09:52:52 +09:00
yarn.lock feat: hc - Hono Client (#862) 2023-02-08 07:22:32 +09:00


Documentation 👉 hono.dev
v3 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 the Edge. It works on Cloudflare Workers, Fastly Compute@Edge, Deno, Bun, Vercel, Lagon, Node.js, and others. Fast, but not only fast.

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

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

export default app

Quick Start

npm create hono@latest my-app

Features

  • Ultrafast - The routers are really fast and smart. Not using linear loops. Fast.
  • Multi-runtime - Works on Cloudflare Workers, Fastly Compute@Edge, Deno, Bun, Lagon, or Node.js. The same code runs on all platforms.
  • Batteries Included - Hono has built-in middleware, custom middleware, and third-party middleware. Batteries included.
  • Fine DX - First-class TypeScript support. Now, we've got "Types".
  • Small - About 20kB. Zero-dependencies. Using only Web Standard API.

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 hono.dev.

Migration

The 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.