Top Related Projects
Expressive middleware for node.js using ES2017 async functions
A progressive Node.js framework for building efficient, scalable, and enterprise-grade server-side applications with TypeScript/JavaScript 🚀
Fast and low overhead web framework, for Node.js
The Simple, Secure Framework Developers Trust
The API and real-time application framework
Quick Overview
Express is a minimal and flexible Node.js web application framework that provides a robust set of features for web and mobile applications. It is designed to make developing web applications and APIs easier and faster, with a focus on simplicity and performance.
Pros
- Lightweight and minimalist, allowing developers to add only what they need
- Large ecosystem of middleware and plugins for extending functionality
- Excellent performance and high test coverage
- Well-documented and widely adopted in the Node.js community
Cons
- Can be overwhelming for beginners due to its flexibility and minimal structure
- Requires additional modules for common web development tasks (e.g., body parsing, cookie handling)
- Lack of built-in structure may lead to inconsistent code organization in large projects
- Not as opinionated as some other frameworks, which may require more decision-making from developers
Code Examples
- Basic Express server:
const express = require('express');
const app = express();
const port = 3000;
app.get('/', (req, res) => {
res.send('Hello World!');
});
app.listen(port, () => {
console.log(`Server running at http://localhost:${port}`);
});
- Handling POST requests with middleware:
const express = require('express');
const app = express();
app.use(express.json());
app.post('/api/users', (req, res) => {
const { name, email } = req.body;
// Process the data (e.g., save to database)
res.json({ message: 'User created successfully' });
});
- Using route parameters:
app.get('/api/users/:id', (req, res) => {
const userId = req.params.id;
// Fetch user data based on userId
res.json({ userId, name: 'John Doe' });
});
Getting Started
To start using Express, follow these steps:
-
Install Express in your project:
npm install express
-
Create a new file (e.g.,
app.js
) and add the following code:const express = require('express'); const app = express(); const port = 3000; app.get('/', (req, res) => { res.send('Hello World!'); }); app.listen(port, () => { console.log(`Server running at http://localhost:${port}`); });
-
Run your application:
node app.js
-
Open a web browser and navigate to
http://localhost:3000
to see your Express application in action.
Competitor Comparisons
Expressive middleware for node.js using ES2017 async functions
Pros of Koa
- Lighter and more expressive middleware system
- Built-in support for async/await
- Smaller codebase, leading to potentially better performance
Cons of Koa
- Smaller ecosystem and fewer middleware options
- Steeper learning curve for developers familiar with Express
- Less widespread adoption in the industry
Code Comparison
Express:
const express = require('express');
const app = express();
app.get('/', (req, res) => {
res.send('Hello World!');
});
Koa:
const Koa = require('koa');
const app = new Koa();
app.use(async ctx => {
ctx.body = 'Hello World!';
});
Both Express and Koa are popular Node.js web application frameworks. Express has been around longer and has a larger ecosystem, while Koa is newer and designed to be more lightweight and flexible.
Express uses a callback-based middleware system, whereas Koa leverages async/await for more readable asynchronous code. Koa's middleware stack is more streamlined, allowing for better composability.
While Express has a larger community and more readily available middleware, Koa's simplicity and modern approach to handling asynchronous operations make it attractive for developers looking for a lightweight alternative.
The choice between Express and Koa often depends on project requirements, team familiarity, and personal preference. Express is generally considered easier for beginners, while Koa may appeal more to developers comfortable with modern JavaScript features.
A progressive Node.js framework for building efficient, scalable, and enterprise-grade server-side applications with TypeScript/JavaScript 🚀
Pros of Nest
- Built-in dependency injection and modular architecture
- TypeScript support out of the box
- Opinionated structure for better scalability and maintainability
Cons of Nest
- Steeper learning curve due to its complex architecture
- Potentially overkill for small projects
- Slightly slower performance compared to Express
Code Comparison
Express:
const express = require('express');
const app = express();
app.get('/', (req, res) => {
res.send('Hello World!');
});
Nest:
import { Controller, Get } from '@nestjs/common';
@Controller()
export class AppController {
@Get()
getHello(): string {
return 'Hello World!';
}
}
Express is minimalist and straightforward, allowing developers to quickly set up routes. Nest, on the other hand, uses decorators and classes, providing a more structured approach but requiring more boilerplate code.
Express is ideal for simple applications or microservices, offering flexibility and ease of use. Nest shines in larger, enterprise-level applications where its opinionated structure and built-in features can significantly improve development efficiency and code organization.
Both frameworks have their strengths, and the choice between them depends on project requirements, team expertise, and scalability needs.
Fast and low overhead web framework, for Node.js
Pros of Fastify
- Higher performance and lower overhead
- Built-in schema validation and serialization
- Extensible plugin system
Cons of Fastify
- Smaller ecosystem and community compared to Express
- Steeper learning curve for developers familiar with Express
- Less documentation and third-party resources available
Code Comparison
Express:
const express = require('express')
const app = express()
app.get('/', (req, res) => {
res.send('Hello World!')
})
Fastify:
const fastify = require('fastify')()
fastify.get('/', async (request, reply) => {
return 'Hello World!'
})
Both Express and Fastify are popular Node.js web frameworks, but they have different design philosophies and features. Express is known for its simplicity and flexibility, making it easy to get started and customize. It has a large ecosystem of middleware and plugins.
Fastify, on the other hand, focuses on performance and developer experience. It offers built-in schema validation, serialization, and a plugin system that allows for easy extension of functionality. Fastify's performance is generally better than Express, especially for high-load applications.
However, Express has a larger community and more resources available, which can be beneficial for beginners or when facing complex issues. Fastify's learning curve might be steeper for developers accustomed to Express, but it offers more modern features out of the box.
The Simple, Secure Framework Developers Trust
Pros of Hapi
- Built-in support for input validation, authentication, and caching
- Modular architecture with a plugin system for better code organization
- Extensive configuration options for fine-tuned control
Cons of Hapi
- Steeper learning curve due to its more opinionated structure
- Less flexibility in routing compared to Express
- Smaller ecosystem and community compared to Express
Code Comparison
Express:
const express = require('express');
const app = express();
app.get('/', (req, res) => {
res.send('Hello World!');
});
Hapi:
const Hapi = require('@hapi/hapi');
const init = async () => {
const server = Hapi.server({ port: 3000 });
server.route({
method: 'GET',
path: '/',
handler: (request, h) => 'Hello World!'
});
await server.start();
};
Both Express and Hapi are popular Node.js web application frameworks, but they have different philosophies and approaches. Express is known for its simplicity and flexibility, making it easier for beginners to get started. It has a large ecosystem of middleware and plugins.
Hapi, on the other hand, provides more built-in functionality and emphasizes configuration over code. It offers robust features out of the box, which can be beneficial for larger, more complex applications. However, this comes at the cost of a steeper learning curve and less flexibility in certain areas.
The choice between Express and Hapi often depends on the specific requirements of the project and the developer's preferences.
The API and real-time application framework
Pros of Feathers
- Built-in real-time functionality and WebSocket support
- Modular architecture with a plugin system for easy extensibility
- Automatic REST API generation for services
Cons of Feathers
- Steeper learning curve due to additional abstractions
- Smaller community and ecosystem compared to Express
- May be overkill for simple applications
Code Comparison
Express:
const express = require('express');
const app = express();
app.get('/', (req, res) => {
res.send('Hello World!');
});
Feathers:
const feathers = require('@feathersjs/feathers');
const express = require('@feathersjs/express');
const app = express(feathers());
app.use('/', (req, res) => {
res.send('Hello World!');
});
Summary
Express is a minimal and flexible web application framework for Node.js, widely used and with a large ecosystem. It provides a robust set of features for web and mobile applications.
Feathers is built on top of Express and provides additional features like real-time capabilities, service-oriented architecture, and built-in support for multiple databases. It's well-suited for real-time applications and APIs but may have a steeper learning curve.
Both frameworks are powerful tools for building web applications, with Express being more lightweight and flexible, while Feathers offers more built-in functionality out of the box.
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual CopilotREADME
Fast, unopinionated, minimalist web framework for Node.js.
This project has a Code of Conduct.
Table of contents
- Installation
- Features
- Docs & Community
- Quick Start
- Running Tests
- Philosophy
- Examples
- Contributing to Express
- TC (Technical Committee)
- Triagers
- License
import express from 'express'
const app = express()
app.get('/', (req, res) => {
res.send('Hello World')
})
app.listen(3000)
Installation
This is a Node.js module available through the npm registry.
Before installing, download and install Node.js. Node.js 18 or higher is required.
If this is a brand new project, make sure to create a package.json
first with
the npm init
command.
Installation is done using the
npm install
command:
npm install express
Follow our installing guide for more information.
Features
- Robust routing
- Focus on high performance
- Super-high test coverage
- HTTP helpers (redirection, caching, etc)
- View system supporting 14+ template engines
- Content negotiation
- Executable for generating applications quickly
Docs & Community
- Website and Documentation - [website repo]
- GitHub Organization for Official Middleware & Modules
- Github Discussions for discussion on the development and usage of Express
PROTIP Be sure to read the migration guide to v5
Quick Start
The quickest way to get started with express is to utilize the executable express(1)
to generate an application as shown below:
Install the executable. The executable's major version will match Express's:
npm install -g express-generator@4
Create the app:
express /tmp/foo && cd /tmp/foo
Install dependencies:
npm install
Start the server:
npm start
View the website at: http://localhost:3000
Philosophy
The Express philosophy is to provide small, robust tooling for HTTP servers, making it a great solution for single page applications, websites, hybrids, or public HTTP APIs.
Express does not force you to use any specific ORM or template engine. With support for over 14 template engines via @ladjs/consolidate, you can quickly craft your perfect framework.
Examples
To view the examples, clone the Express repository:
git clone https://github.com/expressjs/express.git --depth 1 && cd express
Then install the dependencies:
npm install
Then run whichever example you want:
node examples/content-negotiation
Contributing
The Express.js project welcomes all constructive contributions. Contributions take many forms, from code for bug fixes and enhancements, to additions and fixes to documentation, additional tests, triaging incoming pull requests and issues, and more!
See the Contributing Guide for more technical details on contributing.
Security Issues
If you discover a security vulnerability in Express, please see Security Policies and Procedures.
Running Tests
To run the test suite, first install the dependencies:
npm install
Then run npm test
:
npm test
People
The original author of Express is TJ Holowaychuk
TC (Technical Committee)
- UlisesGascon - Ulises Gascón (he/him)
- jonchurch - Jon Church
- wesleytodd - Wes Todd
- LinusU - Linus Unnebäck
- blakeembrey - Blake Embrey
- sheplu - Jean Burellier
- crandmck - Rand McKinney
- ctcpip - Chris de Almeida
TC emeriti members
TC emeriti members
- dougwilson - Douglas Wilson
- hacksparrow - Hage Yaapa
- jonathanong - jongleberry
- niftylettuce - niftylettuce
- troygoode - Troy Goode
Triagers
- aravindvnair99 - Aravind Nair
- bjohansebas - Sebastian Beltran
- carpasse - Carlos Serrano
- CBID2 - Christine Belzie
- enyoghasim - David Enyoghasim
- UlisesGascon - Ulises Gascón (he/him)
- mertcanaltin - Mert Can Altin
- 0ss - Salah
- import-brain - Eric Cheng (he/him)
- 3imed-jaberi - Imed Jaberi
- dakshkhetan - Daksh Khetan (he/him)
- lucasraziel - Lucas Soares Do Rego
- IamLizu - S M Mahmudul Hasan (he/him)
- Sushmeet - Sushmeet Sunger
- rxmarbles Rick Markins (He/him)
Triagers emeriti members
Emeritus Triagers
- AuggieH - Auggie Hudak
- G-Rath - Gareth Jones
- MohammadXroid - Mohammad Ayashi
- NawafSwe - Nawaf Alsharqi
- NotMoni - Moni
- VigneshMurugan - Vignesh Murugan
- davidmashe - David Ashe
- digitaIfabric - David
- e-l-i-s-e - Elise Bonner
- fed135 - Frederic Charette
- firmanJS - Firman Abdul Hakim
- getspooky - Yasser Ameur
- ghinks - Glenn
- ghousemohamed - Ghouse Mohamed
- gireeshpunathil - Gireesh Punathil
- jake32321 - Jake Reed
- jonchurch - Jon Church
- lekanikotun - Troy Goode
- marsonya - Lekan Ikotun
- mastermatt - Matt R. Wilson
- maxakuru - Max Edell
- mlrawlings - Michael Rawlings
- rodion-arr - Rodion Abdurakhimov
- sheplu - Jean Burellier
- tarunyadav1 - Tarun yadav
- tunniclm - Mike Tunnicliffe
License
Top Related Projects
Expressive middleware for node.js using ES2017 async functions
A progressive Node.js framework for building efficient, scalable, and enterprise-grade server-side applications with TypeScript/JavaScript 🚀
Fast and low overhead web framework, for Node.js
The Simple, Secure Framework Developers Trust
The API and real-time application framework
Convert designs to code with AI
Introducing Visual Copilot: A new AI model to turn Figma designs to high quality code using your components.
Try Visual Copilot