Book Image

MEAN Cookbook

By : Nicholas McClay
Book Image

MEAN Cookbook

By: Nicholas McClay

Overview of this book

The MEAN Stack is a framework for web application development using JavaScript-based technologies; MongoDB, Express, Angular, and Node.js. If you want to expand your understanding of using JavaScript to produce a fully functional standalone web application, including the web server, user interface, and database, then this book can help guide you through that transition. This book begins by configuring the frontend of the MEAN stack web application using the Angular JavaScript framework. We then implement common user interface enhancements before moving on to configuring the server layer of our MEAN stack web application using Express for our backend APIs. You will learn to configure the database layer of your MEAN stack web application using MongoDB and the Mongoose framework, including modeling relationships between documents. You will explore advanced topics such as optimizing your web application using WebPack as well as the use of automated testing with the Mocha and Chai frameworks. By the end of the book, you should have acquired a level of proficiency that allows you to confidently build a full production-ready and scalable MEAN stack application.
Table of Contents (13 chapters)

Uploading large multi-part files with Express

Before we wade into adding dependencies for external services and APIs in application, let's start with understanding how to implement the basics of a feature without any external dependencies. It's always worth considering the trade-offs involved in building your own solution to a problem versus leveraging an external cloud service to assist.

File uploading is a very common feature in web applications. From documents to images, files that need to be transferred from a user's desktop to any web service have to go through a multipart/form-data file upload. In this recipe, we will add a backend API to upload images to our Express application, which we could then use to add a cover image to our blog posts.

Getting ready

...