- Identify how different components of a MEAN app work together
- Build a simple MEAN app with data persistence, and dynamic views
- Provide an example of a MEAN app
So far we've studied Express, Mongo, Mongoose, and Angular in isolation, as well as have learned how to build a simple MEN app.
Today we'll complete the MEAN stack by adding Angular to WhenPresident.
The term MEAN was coined by a developer at Mongo in a blog post discussing his team's workflow. His insights are as follows:
"By coding with Javascript throughout, we are able to realize performance gains in both the software itself and in the productivity of our developers...With MongoDB, we can store our documents in a JSON-like format, write JSON queries on our ExpressJS and NodeJS based server, and seamlessly pass JSON documents to our AngularJS front-end."
Now self-promotion aside, his rationale is widely shared around the industry, as MEAN stack apps have risen in popularity since Node, Mongo, Express, and Angular were introduced in 2012.
Some popular MEAN apps in production include Airpair, Open Graph, and StartHQ
Ok, sure it's trendy, but why should we use the MEAN stack?
Let's review the use cases for each component:
Why use Express?
Express is a minimal and flexible Node.js web application framework that provides a robust set of features for building web apps. Express works with a myriad of HTTP utility methods and middleware that allows developers to create robust APIs quickly and easily
Why use Mongo?
MongoDB is an open-source document database that provides high performance, high availability, and automatic scaling
Why use Mongoose?
Like ActiveRecord for Rails, Mongoose is an ODM used to represent data from a Mongo database as models in a Javascript back-end. This makes performing CRUD actions to collections and documents in our DB easier.
Why use Angular?
AngularJS is a robust front-end framework that makes it possible to easily and quickly build Single Page Applications. It has lots of functionality built in for rendering data, and swapping views in and out to give the impression of having multiple pages. It is fully extensible and works well with other libraries.
Each of the technologies have their own benefits, but combined, there is power in the ability to work with the same type of objects from the DB, to the Server, to the View, and it is easy for teams to collaborate since it's Javascript throughout the stack.
"Debugging and database administration become a lot easier when the objects stored in your database are essentially identical to the objects your client Javascript sees. Even better, somebody working on the client side can easily understand the server side code and database queries; using the same syntax and objects the whole way through frees you from having to consider multiple sets of language best practices and reduces the barrier to entry for understanding your codebase."
To get a sense of our built out application, let's look at the deployed When President Solution. Playing around with our deployed app, we can see that it is a SPA, and there are no page refreshes, so Angular is doing the heaving lifting with the view.
You have already created a MEN app with WhenPresident. We are now going to walkthrough adding Angular to the app whenpresident.
- What advantages does the MEAN stack offer?
- When type of applications are best suited for the MEAN stack?
- What is HTML5 Mode and how does it affect our angular apps?
- What is the role of
body-parser
in the request-response cycle?