0
0
mirror of https://github.com/honojs/hono.git synced 2024-11-29 17:46:30 +01:00
Web Framework built on Web Standards https://hono.dev/
Go to file
Yusuke Wada 4a9cd272f8
refactor(types): reduce type definitions (#649)
* refactor(types): reduce type definitions

* fixed tests for Deno and Bun
2022-11-03 15:53:41 +09:00
.github chore: add FUNDING.yml (#468) 2022-08-15 08:58:39 +09:00
.vscode feat(validator): add support for JSON array path validation (#563) 2022-09-30 21:56:39 +09:00
benchmarks chore(benchmark): update benchmark scripts for Deno 2022-09-21 10:31:21 +09:00
bun_test refactor(types): reduce type definitions (#649) 2022-11-03 15:53:41 +09:00
deno_dist refactor(types): reduce type definitions (#649) 2022-11-03 15:53:41 +09:00
deno_test refactor(types): reduce type definitions (#649) 2022-11-03 15:53:41 +09:00
docs docs(contribution): update about 3rd-party middleware (#619) 2022-10-23 07:01:04 +09:00
src refactor(types): reduce type definitions (#649) 2022-11-03 15:53:41 +09:00
.eslintignore Setup lint to enable code styles check (#27) 2022-01-07 07:03:54 +09:00
.eslintrc.cjs fix(build): fix ESM support in Node.js / use esbuild (#631) 2022-10-28 08:46:02 +09:00
.gitignore chore(git): ignore bun.lockb 2022-07-29 08:21:23 +09:00
.npmignore refactor: refine directory structure (#156) 2022-04-20 14:06:04 +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 fix(build): fix ESM support in Node.js / use esbuild (#631) 2022-10-28 08:46:02 +09:00
LICENSE Create LICENSE (#1) 2021-12-15 05:06:31 +09:00
package.cjs.json fix(typo): package.cjs.json target to type (#634) 2022-10-29 16:09:32 +09:00
package.json v2.4.1 2022-11-01 21:44:20 +09:00
README.md docs(readme): update! 2022-09-20 23:06:05 +09:00
tsconfig.build.json refactor(types): refactor and add tests for checking Types (#615) 2022-10-23 08:10:00 +09:00
tsconfig.json refactor(types): refactor and add tests for checking Types (#615) 2022-10-23 08:10:00 +09:00
yarn.lock fix(build): fix ESM support in Node.js / use esbuild (#631) 2022-10-28 08:46:02 +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 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 fastest, compared to other routers for Cloudflare Workers.

Hono x 616,464 ops/sec ±4.76% (83 runs sampled)
itty-router x 203,074 ops/sec ±3.66% (88 runs sampled)
sunder x 314,306 ops/sec ±2.28% (87 runs sampled)
worktop x 194,111 ops/sec ±2.78% (81 runs sampled)
Fastest is Hono
✨  Done in 30.77s.

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.