Get Advice Icon

Need advice about which tool to choose?Ask the StackShare community!

ExpressJS
ExpressJS

6.1K
4.5K
+ 1
1.3K
hapi
hapi

292
216
+ 1
80
Sails.js
Sails.js

241
194
+ 1
226

What is ExpressJS?

Express is a minimal and flexible node.js web application framework, providing a robust set of features for building single and multi-page, and hybrid web applications.

What is hapi?

hapi is a simple to use configuration-centric framework with built-in support for input validation, caching, authentication, and other essential facilities for building web applications and services.

What is Sails.js?

Sails is designed to mimic the MVC pattern of frameworks like Ruby on Rails, but with support for the requirements of modern apps: data-driven APIs with scalable, service-oriented architecture.
Get Advice Icon

Need advice about which tool to choose?Ask the StackShare community!

Why do developers choose ExpressJS?
Why do developers choose hapi?
Why do developers choose Sails.js?

Sign up to add, upvote and see more prosMake informed product decisions

    Be the first to leave a con
    What companies use ExpressJS?
    What companies use hapi?
    What companies use Sails.js?

    Sign up to get full access to all the companiesMake informed product decisions

    What tools integrate with ExpressJS?
    What tools integrate with hapi?
    What tools integrate with Sails.js?

    Sign up to get full access to all the tool integrationsMake informed product decisions

    What are some alternatives to ExpressJS, hapi, and Sails.js?
    Koa
    Koa aims to be a smaller, more expressive, and more robust foundation for web applications and APIs. Through leveraging generators Koa allows you to ditch callbacks and greatly increase error-handling. Koa does not bundle any middleware.
    React
    Lots of people use React as the V in MVC. Since React makes no assumptions about the rest of your technology stack, it's easy to try it out on a small feature in an existing project.
    Flask
    Flask is intended for getting started very quickly and was developed with best intentions in mind.
    Django
    Django is a high-level Python Web framework that encourages rapid development and clean, pragmatic design.
    Go
    Go is expressive, concise, clean, and efficient. Its concurrency mechanisms make it easy to write programs that get the most out of multicore and networked machines, while its novel type system enables flexible and modular program construction. Go compiles quickly to machine code yet has the convenience of garbage collection and the power of run-time reflection. It's a fast, statically typed, compiled language that feels like a dynamically typed, interpreted language.
    See all alternatives
    Decisions about ExpressJS, hapi, and Sails.js
    Antonio Kobashikawa
    Antonio Kobashikawa
    Web developer | Blogger | Freelancer at Rulo Kobashikawa | 5 upvotes 57.1K views
    Node.js
    Node.js
    ExpressJS
    ExpressJS
    MongoDB
    MongoDB
    Vue.js
    Vue.js
    Ionic
    Ionic
    JavaScript
    JavaScript
    ES6
    ES6
    Koa
    Koa

    We are using Node.js and ExpressJS to build a REST services that is middleware of a legacy system. MongoDB as database. Vue.js helps us to make rapid UI to test use cases. Frontend is build for mobile with Ionic . We like using JavaScript and ES6 .

    I think next step could be to use Koa but I am not sure.

    See more
    Docker
    Docker
    Docker Compose
    Docker Compose
    Jenkins
    Jenkins
    Kubernetes
    Kubernetes
    Amazon EC2
    Amazon EC2
    Heroku
    Heroku
    FeathersJS
    FeathersJS
    Node.js
    Node.js
    ExpressJS
    ExpressJS
    PostgreSQL
    PostgreSQL
    React
    React
    Redux
    Redux
    Semantic UI React
    Semantic UI React
    AVA
    AVA
    ESLint
    ESLint
    nginx
    nginx
    GitHub
    GitHub
    #Containerized
    #Containers
    #Backend
    #Stack
    #Frontend

    Recently I have been working on an open source stack to help people consolidate their personal health data in a single database so that AI and analytics apps can be run against it to find personalized treatments. We chose to go with a #containerized approach leveraging Docker #containers with a local development environment setup with Docker Compose and nginx for container routing. For the production environment we chose to pull code from GitHub and build/push images using Jenkins and using Kubernetes to deploy to Amazon EC2.

    We also implemented a dashboard app to handle user authentication/authorization, as well as a custom SSO server that runs on Heroku which allows experts to easily visit more than one instance without having to login repeatedly. The #Backend was implemented using my favorite #Stack which consists of FeathersJS on top of Node.js and ExpressJS with PostgreSQL as the main database. The #Frontend was implemented using React, Redux.js, Semantic UI React and the FeathersJS client. Though testing was light on this project, we chose to use AVA as well as ESLint to keep the codebase clean and consistent.

    See more
    Paul Whittemore
    Paul Whittemore
    Developer and Owner at Appurist Software | 15 upvotes 112.4K views
    Fastify
    Fastify
    ExpressJS
    ExpressJS
    Node.js
    Node.js
    Vuetify
    Vuetify
    Quasar Framework
    Quasar Framework
    Vue.js
    Vue.js
    vuex
    vuex
    Electron
    Electron
    Fastly
    Fastly

    I'm building most projects using: Server: either Fastify (all projects going forward) or ExpressJS on Node.js (existing, previously) on the server side, and Client app: either Vuetify (currently) or Quasar Framework (going forward) on Vue.js with vuex on Electron for the UI to deliver both web-based and desktop applications for multiple platforms.

    The direct support for Android and iOS in Quasar Framework will make it my go-to client UI platform for any new client-side or web work. On the server, I'll probably use Fastly for all my server work, unless I get into Go more in the future.

    Update: The mobile support in Quasar is not a sufficiently compelling reason to move me from Vuetify. I have decided to stick with Vuetify for a UI for Vue, as it is richer in components and enables a really great-looking professional result. For mobile platforms, I will just use Cordova to wrap the Vue+Vuetify app for mobile, and Electron to wrap it for desktop platforms.

    See more
    Praveen Mooli
    Praveen Mooli
    Technical Leader at Taylor and Francis | 11 upvotes 222.4K views
    MongoDB Atlas
    MongoDB Atlas
    Java
    Java
    Spring Boot
    Spring Boot
    Node.js
    Node.js
    ExpressJS
    ExpressJS
    Python
    Python
    Flask
    Flask
    Amazon Kinesis
    Amazon Kinesis
    Amazon Kinesis Firehose
    Amazon Kinesis Firehose
    Amazon SNS
    Amazon SNS
    Amazon SQS
    Amazon SQS
    AWS Lambda
    AWS Lambda
    Angular 2
    Angular 2
    RxJS
    RxJS
    GitHub
    GitHub
    Travis CI
    Travis CI
    Terraform
    Terraform
    Docker
    Docker
    Serverless
    Serverless
    Amazon RDS
    Amazon RDS
    Amazon DynamoDB
    Amazon DynamoDB
    Amazon S3
    Amazon S3
    #Backend
    #Microservices
    #Eventsourcingframework
    #Webapps
    #Devops
    #Data

    We are in the process of building a modern content platform to deliver our content through various channels. We decided to go with Microservices architecture as we wanted scale. Microservice architecture style is an approach to developing an application as a suite of small independently deployable services built around specific business capabilities. You can gain modularity, extensive parallelism and cost-effective scaling by deploying services across many distributed servers. Microservices modularity facilitates independent updates/deployments, and helps to avoid single point of failure, which can help prevent large-scale outages. We also decided to use Event Driven Architecture pattern which is a popular distributed asynchronous architecture pattern used to produce highly scalable applications. The event-driven architecture is made up of highly decoupled, single-purpose event processing components that asynchronously receive and process events.

    To build our #Backend capabilities we decided to use the following: 1. #Microservices - Java with Spring Boot , Node.js with ExpressJS and Python with Flask 2. #Eventsourcingframework - Amazon Kinesis , Amazon Kinesis Firehose , Amazon SNS , Amazon SQS, AWS Lambda 3. #Data - Amazon RDS , Amazon DynamoDB , Amazon S3 , MongoDB Atlas

    To build #Webapps we decided to use Angular 2 with RxJS

    #Devops - GitHub , Travis CI , Terraform , Docker , Serverless

    See more
    Samuel Olugbemi
    Samuel Olugbemi
    Software Engineer at Payzone UK | 6 upvotes 21.8K views
    atPayzone UKPayzone UK
    LoopBack
    LoopBack
    ExpressJS
    ExpressJS

    I use LoopBack because it is: * It is truly and Unbelievably Extensible * it is default integrated with OpenAPI (Swagger) Spec Driven REST API * I write lesser codes, because most of the user stories have been covered using the code generation * It's documentation is more compact and well detailed than ExpressJS * It is very easy to learn, hence you can build a basic Rest API App in minutes * It has built in NPM packages required to build my Rest API which saves me time on installation and configuration * The Datasource/Service/Controller concept is just Brilliant (that's mostly all you need to get your app speaking with an External API services) * The support for SOAP and Rest API services is amazing!

    See more
    Interest over time
    Reviews of ExpressJS, hapi, and Sails.js
    No reviews found
    How developers use ExpressJS, hapi, and Sails.js
    Avatar of Cloudcraft
    Cloudcraft uses ExpressJSExpressJS

    Express.js is the workhorse of the Cloudcraft.co backend. It's not the most exciting part of a stack, but it works, is very well documented, and you can find a plugin for almost everything you could possibly want. We also carefully evaluated Koa.js, but decided not to go down this route: fewer plugins, less documentation & answers online. I'm also not personally convinced by the generators yield syntax at all. ES7 async functions looks like a much better bet, and with Promises and Babel I can have that already today.

    Avatar of Volkan 脰z莽elik
    Volkan 脰z莽elik uses ExpressJSExpressJS

    I use express.js for nightly.zerotoherojs.com and dojo.zerotoherojs.com web apps.

    Express is well-known, lightweight, works out-of-the-box, has great middleware support and has minimal learning curve.

    It is the best framework to start developing a general Node.js web app.

    Avatar of Kent Steiner
    Kent Steiner uses ExpressJSExpressJS

    I'm fluent in ExpressJS, but over the past two years I have moved to HapiJS. Similar results, but I find Hapi to be more full-featured towards my app, api and service needs. I can operate confidently in both.

    Avatar of Promethean TV
    Promethean TV uses ExpressJSExpressJS

    PrometheanTV utilizes the ExpressJS web application framework to deploy various web applications and services including the Broadcast Center Tool, our video embed service, and our REST API.

    Avatar of Merge In
    Merge In uses ExpressJSExpressJS

    We rely on ExpressJS to serve our content simply, easily, and effectively, without the bloat-ware. Big thanks to StrongLoop for supporting this package.

    Avatar of Thibault Maekelbergh
    Thibault Maekelbergh uses hapihapi

    Serves static content. Was added to make it more easy to transition to serverside view templating and API.

    Avatar of Ian Kelly
    Ian Kelly uses hapihapi

    Web framework for building RESTful APIs in Javascript.

    Avatar of Cotalented
    Cotalented uses Sails.jsSails.js

    Sails serves the API backend

    Avatar of Dave Woolfenden
    Dave Woolfenden uses hapihapi

    REST libraries usage

    How much does ExpressJS cost?
    How much does hapi cost?
    How much does Sails.js cost?
    Pricing unavailable
    Pricing unavailable
    Pricing unavailable
    News about ExpressJS
    More news
    News about hapi
    More news
    News about Sails.js
    More news