Popularity
5.5
Growing
Activity
9.8
Growing
1,301
15
48

Description

tinyhttp is a modern Express-like web framework written in TypeScript and compiled to native ESM, that uses a bare minimum amount of dependencies trying to avoid legacy hell.

Here is a short list of most important features that tinyhttp has:

- ⚡ 2.3x faster than Express - ⚙ Full Express middleware support - ↪ Async middleware support - ☑ Native ESM and CommonJS support - 🚀 No legacy dependencies, just the JavaScript itself - 🔨 Types out of the box

Programming language: TypeScript
License: MIT License
Tags: Nodejs     API     Express     Web Frameworks     HTTP     Framework     TypeScript     Server     Node     JavaScript     REST     Routing     Commonjs     App     Web     Request     Router     Middleware     ESM    
Latest version: v1.0.0

tinyhttp alternatives and similar modules

Based on the "Web Frameworks" category.
Alternatively, view tinyhttp alternatives based on common mentions on social networks and blogs.

Do you think we are missing an alternative of tinyhttp or a related project?

Add another 'Web Frameworks' Module

README

tinyhttp ⚡ Tiny web framework as a replacement of Express

npm GitHub Workflow Status Codecov Vulnerabilities Codacy grade Last commit NPM

tinyhttp is a modern Express-like web framework written in TypeScript and compiled to native ESM, that uses a bare minimum amount of dependencies trying to avoid legacy hell.

Here is a short list of most important features that tinyhttp has:

  • ⚡ [2x faster](benchmark) than Express
  • ⚙ Full Express middleware support
  • ↪ Async middleware support
  • ☑ Native ESM and CommonJS support
  • 🚀 No legacy dependencies, just the JavaScript itself
  • 🔨 Types out of the box
  • 🔥 Prebuilt middleware for modern Node.js

Visit tinyhttp website for docs, guides and middleware search.

Install

tinyhttp requires Node.js 12.4.0 or newer. It is recommended to use pnpm, although it isn't required.

# npm
npm i @tinyhttp/app
# pnpm
pnpm i @tinyhttp/app
# yarn
yarn add @tinyhttp/app

Docs

You can see the documentation here.

Get Started

tinyhttp is compiled to ESM (and legacy CommonJS) so you can use import / export syntax in Node.js with it.

To setup a Node ESM package, put "type": "module" in the package.json file, like this:

{
  "type": "module"
}

Another option would be using an .mjs extension, then you don't need to put that "type" field in package.json.

For more info, check out the ECMAScript Modules Node.js documentation.

From now on you can use named imports for ESM modules and default imports for CommonJS modules in your project.

The app structure is quite similar to Express, except that you need to import App from @tinyhttp/app instead of default import from express.

import { App } from '@tinyhttp/app'
import { logger } from '@tinyhttp/logger'

const app = new App()

app
  .use(logger())
  .use(function someMiddleware(req, res, next) {
    console.log('Did a request')
    next()
  })
  .get('/', (_, res) => {
    res.send('<h1>Hello World</h1>')
  })
  .get('/page/:page/', (req, res) => {
    res.status(200).send(`You just opened ${req.params.page}`)
  })
  .listen(3000)

See tinyhttp "Learn" page for complete guide.

Middlewares

tinyhttp offers a list of premade middleware for common tasks, such as session, logger and jwt.

Search and explore the full list at middleware search page.

Comparison

See [COMPARISON.md](COMPARISON.md).

Benchmarks

Check [benchmark](benchmark) folder.

Contributing

See [CONTRIBUTING.md](CONTRIBUTING.md).

Contributors ✨

Thanks goes to these wonderful people (emoji key):

<!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section --> <!-- prettier-ignore-start --> <!-- markdownlint-disable --> v 1 r t l💡 🔌 📆 🚧 💻 Matt🔌 ⚠️ Nasmevka📖 elianiva💡 🚧 💻 ⚠️ Katja Lutz💡 Arnovsky🔌 💻 Rocktim Saikia🚇 💻 💡 Ahmad Reza💻 Ionel lupu💡 Tomi Kalmi📖 Luiginator💡 💻 Aneesh Relan💡 ⚠️ Roberto Ortega💡 Barciet Maëlann💡 shzmr💻 ⚠️ 💡 Egor Avakumov💡 Rashmi K A💻 Shubhi Agarwal⚠️ Maurizio⚠️ 💻 jkreller💡 Alan Carpilovsky⚠️ KoljaTM⚠️ ike📖 💡 Fabian Morón Zirfas🐛 Vitaly Baev⚠️ 🐛 omrilotan💻 MVEMCJSUNPE💡 🐛

<!-- markdownlint-enable --> <!-- prettier-ignore-end --> <!-- ALL-CONTRIBUTORS-LIST:END -->

This project follows the all-contributors specification. Contributions of any kind welcome!

Supporters 💰

These amazing people supported tinyhttp financially:

<!-- prettier-ignore-start --> <!-- markdownlint-disable --> molefrog <!-- markdownlint-enable --> <!-- prettier-ignore-end -->

License

MIT © v1rtl


*Note that all licence references and agreements mentioned in the tinyhttp README section above are relevant to that project's source code only.