Getting MEAN with Mongo, Express, Angular, and Node, Second

Total Page:16

File Type:pdf, Size:1020Kb

Getting MEAN with Mongo, Express, Angular, and Node, Second MEAP Edition Manning Early Access Program Getting MEAN with Mongo, Express, Angular, and Node Second Edition Version 9 Copyright 2019 Manning Publications For more information on this and other Manning titles go to www.manning.com ©Manning Publications Co. We welcome reader comments about anything in the manuscript - other than typos and other simple mistakes. These will be cleaned up during production of the book by copyeditors and proofreaders. https://forums.manning.com/forums/getting-mean-with-mongo-express-angular-and-node-second-edition welcome Thank you for purchasing the MEAP for Getting MEAN Second Edition. I’m excited to see the book reach this stage and look forward to its continued development and eventual release. This is an intermediate book, designed for anyone with web-development experience— particularly with some exposure to JavaScript—who wants to learn how to be a full-stack developer or see how the whole MEAN stack fits together. I’ve strived to make the content both approachable and meaningful, and to explain not just how to do things with the MEAN stack but also why things are done the way they are. I feel it is important to know about each part of the MEAN stack before diving in to building an application. To start, chapter 1 is an overview of what full stack development means, and the roles MongoDB, Express, Angular, and Node.js each play generally in forming the MEAN stack. Chapter 2 takes a closer look at a few of the ways you can use the MEAN stack (there isn’t just one “right” way to do it!). We’ll explore a couple of scenarios and show how you can combine the components of the MEAN stack in different ways to meet the requirements of your project. And in chapter 3, we’ll get started building our example app, Loc8r. Loc8r will be a responsive web application, with an aim of listing places nearby that based on current location. Chapter 3 will see us setting up a base project using Node and Express, and also pushing it to a live environment for testing. Looking ahead, the book will continue to cover building a responsive, data-driven web application using Node.js, Express, and MongoDB, with a cast of supporting technologies. Part 3 will complete the MEAN stack by adding an Angular single page application as the front-end to the application. As you’re reading, I hope you’ll take advantage of the Author Online forum. I’ll be reading your comments and responding, and your feedback is helpful in the development process. —Simon Holmes and Clive Harber ©Manning Publications Co. We welcome reader comments about anything in the manuscript - other than typos and other simple mistakes. These will be cleaned up during production of the book by copyeditors and proofreaders. https://forums.manning.com/forums/getting-mean-with-mongo-express-angular-and-node-second-edition brief contents PART 1: SETTING THE BASELINE 1 Introducing full-stack development 2 Designing a MEAN stack architecture PART 2: BUILDING A NODE WEB APPLICATION 3 Creating and setting up a MEAN project 4 Building a static site with Node and Express 5 Building a data model with MongoDB and Mongoose 6 Writing a REST API: Exposing the MongoDB database to the application 7 Consuming a REST API: Using an API from inside Express PART 3: ADDING A DYNAMIC FRONT END WITH ANGULAR 8 Creating an Angular application with TypeScript 9 Building a Single Page Application with Angular: Foundations 10 Building a Single Page Application with Angular: The next level PART 4: MANAGING AUTHENTICATION AND USER SESSIONS 11 Authenticating users, managing sessions and securing APIs 12 Using an authentication API in Angular applications APPENDIXES: A Installing the stack B Installing and preparing the supporting cast C Dealing with all of the views D Reintroducing JavaScript ©Manning Publications Co. We welcome reader comments about anything in the manuscript - other than typos and other simple mistakes. These will be cleaned up during production of the book by copyeditors and proofreaders. https://forums.manning.com/forums/getting-mean-with-mongo-express-angular-and-node-second-edition 1 1 Introducing full-stack development This chapter covers • The benefits of full-stack development • An overview of the MEAN stack components • What makes the MEAN stack so compelling • A preview of the application we’ll build throughout this book If you’re like me then you’re probably impatient to dive into some code and get on with building something. But let’s take a moment first to clarify what is meant by full-stack development, and look at the component parts of the stack to make sure you understand each. When I talk about full-stack development, I’m really talking about developing all parts of a website or application. The full stack starts with the database and web server in the back end, contains application logic and control in the middle, and goes all the way through to the user interface at the front end. The MEAN stack is a pure JavaScript stack comprised of four main technologies, with a cast of supporting technologies: • MongoDBthe database • Expressthe web framework • Angularthe front-end framework • Node.jsthe web server MongoDB has been around since 2007, and is actively maintained by MongoDB Inc., previously known as 10gen. Express was first released in 2009 by T. J. Holowaychuk and has since become the most popular framework for Node.js. It’s open source, with more than 100 contributors, and is actively developed and supported. ©Manning Publications Co. We welcome reader comments about anything in the manuscript - other than typos and other simple mistakes. These will be cleaned up during production of the book by copyeditors and proofreaders. https://forums.manning.com/forums/getting-mean-with-mongo-express-angular-and-node-second-edition 2 Angular is open source and backed by Google. The first version of Angular – known as AngularJS or Angular 1 - has been around since 2010. Angular 2 – now known simply as Angular – was officially released in 2016 and is constantly being developed and extended. At the time of writing we are now on Angular 6; Angular 2+ is not backward-compatible with AngularJS. See the Angular versions and release cycles sidebar for a bit more information about the number and release cycles. Angular versions and release cycles The change from Angular 1.x to Angular 2 was a big deal in the developer community. It was a long time coming, very different and not backwards compatible. But now Angular are releasing versions much more frequently, aiming for every six months. At the time of writing we’re on Angular 6, with 7 already being heavily worked on. The frequency of change is nothing to worry about though, the changes are nowhere near as big as the complete re- write that happened between 1.x and 2.0. The changes are generally small incremental changes. There may be some breaking changes between 4 and 5, or 5 and 6 but these are normally small, specific items that are easy to pick up. It is very different from the change from Angular 1.x to 2.0. Node.js was created in 2009, and its development and maintenance are currently under the purview of the Node Foundation, of which Joyent the organization that created Node is a major member. Node.js uses Google’s open source V8 JavaScript engine at its core. 1.1 Why learn the full stack? So, indeed, why learn the full stack? It sounds like an awful lot of work! Well yes, it is quite a lot of work, but it’s also very rewarding as you get to create fully functioning data-driven websites and applications all by yourself. And with the MEAN stack it isn’t as hard as you might think. 1.1.1 A very brief history of web development Back in the early days of the web, people didn’t have high expectations of websites. Not much emphasis was given to presentation; it was much more about what was going on behind the scenes. Typically, if you knew something like Perl and could string together a bit of HTML then you were a web developer. As use of the internet spread, businesses started to take more of an interest in how their online presence portrayed them. In combination with the increased browser support of Cascading Style Sheets (CSS) and JavaScript, this desire started to lead to more complicated front-end implementations. It was no longer a case of being able to string together HTML; you needed to spend time on CSS and JavaScript, making sure it looked right and worked as expected. And all of this needed to work in different browsers, which were much less compliant than they are today. ©Manning Publications Co. We welcome reader comments about anything in the manuscript - other than typos and other simple mistakes. These will be cleaned up during production of the book by copyeditors and proofreaders. https://forums.manning.com/forums/getting-mean-with-mongo-express-angular-and-node-second-edition 3 This is where the distinction between front-end developer and back-end developer came in. Figure 1.1 illustrates this separation over time. Figure 1.1 Divergence of front-end and back-end developers over time While the back-end developers were focused on the mechanics behind the scenes, the front- end developers focused on building a good user experience. As time went on, higher expectations were made of both camps, encouraging this trend to continue. Developers often had to choose an expertise and focus on it.
Recommended publications
  • Marketing Cloud Published: August 12, 2021
    Marketing Cloud Published: August 12, 2021 The following are notices required by licensors related to distributed components (mobile applications, desktop applications, or other offline components) applicable to the services branded as ExactTarget or Salesforce Marketing Cloud, but excluding those services currently branded as “Radian6,” “Buddy Media,” “Social.com,” “Social Studio,”“iGoDigital,” “Predictive Intelligence,” “Predictive Email,” “Predictive Web,” “Web & Mobile Analytics,” “Web Personalization,” or successor branding, (the “ET Services”), which are provided by salesforce.com, inc. or its affiliate ExactTarget, Inc. (“salesforce.com”): @formatjs/intl-pluralrules Copyright (c) 2019 FormatJS Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
    [Show full text]
  • Open Source Licenses Visionize Lab Suite the Software of Visionize Lab Suite Contains Open Source Licenses Included in This Document
    Open Source Licenses VisioNize Lab Suite The software of VisioNize Lab Suite contains open source licenses included in this document. Package name License Website/Repository Publisher/Author @angular-devkit/[email protected] MIT https://github.com/angular/angular-cli Angular Authors @angular-devkit/[email protected] MIT https://github.com/angular/angular-cli Angular Authors @angular-devkit/build-optimiz- MIT https://github.com/angular/angular-cli Angular Authors [email protected] @angular-devkit/build-web- MIT https://github.com/angular/angular-cli Angular Authors [email protected] @angular-devkit/[email protected] MIT https://github.com/angular/angular-cli Angular Authors @angular-devkit/[email protected] MIT https://github.com/angular/angular-cli Angular Authors @angular/[email protected] MIT https://github.com/angular/angular angular @angular/[email protected] MIT https://github.com/angular/angular-cli Angular Authors @angular/[email protected] MIT https://github.com/angular/angular angular @angular/[email protected] MIT https://github.com/angular/angular @angular/[email protected] MIT https://github.com/angular/angular angular @angular/[email protected] MIT https://github.com/angular/angular angular @angular/[email protected] MIT https://github.com/angular/angular angular @angular/[email protected] MIT https://github.com/angular/angular angular @angular/platform-browser-dynam- MIT https://github.com/angular/angular angular [email protected] @angular/[email protected] MIT https://github.com/angular/angular angular @angular/[email protected] MIT https://github.com/angular/angular angular
    [Show full text]
  • Backbone Tutorials
    Backbone Tutorials Beginner, Intermediate and Advanced ©2012 Thomas Davis This version was published on 2012-10-16 This is a Leanpub book, for sale at: http://leanpub.com/backbonetutorials Leanpub helps authors to self-publish in-progress ebooks. We call this idea Lean Publishing. To learn more about Lean Publishing, go to: http://leanpub.com/manifesto To learn more about Leanpub, go to: http://leanpub.com Tweet This Book! Please help Thomas Davis by spreading the word about this book on Twitter! The suggested hashtag for this book is #backbonetutorials. Find out what other people are saying about the book by clicking on this link to search for this hashtag on Twitter: https://twitter.com/search/#backbonetutorials Contents Why do you need Backbone.js? i Why single page applications are the future ............................ i So how does Backbone.js help? ................................... i Other frameworks .......................................... i Contributors .......................................... i What is a view? ii The “el” property ........................................... ii Loading a template .......................................... iii Listening for events .......................................... iii Tips and Tricks ............................................ iv Relevant Links ......................................... v Contributors .......................................... v What is a model? vi Setting attributes ........................................... vi Getting attributes ..........................................
    [Show full text]
  • Pronghorn-Licenses-V2.Pdf
    Pronghorn Application Server is @copyright Itential, LLC 2015. Pronghorn uses open source software. Pronghorn has direct dependencies on the following software. Name License URI ---------------------------------------------------------------------------------------------------- angular-animate MIT https://github.com/angular/angular.js angular-aria MIT https://github.com/angular/angular.js angular-material MIT https://github.com/angular/material angular MIT https://github.com/angular/angular.js body-parser MIT https://github.com/expressjs/body-parser bootstrap MIT https://github.com/twbs/bootstrap btoa Apache 2.0 https://github.com/coolaj86/node-browser-compat caller-id MIT https://github.com/pixelsandbytes/caller-id continuation-local-storage BSD https://github.com/othiym23/node-continuation-local-storage cookie-parser MIT https://github.com/expressjs/cookie-parser diff BSD https://github.com/kpdecker/jsdiff express-generator MIT https://github.com/expressjs/generator express-session MIT https://github.com/expressjs/session express MIT https://github.com/strongloop/express forever MIT https://github.com/nodejitsu/forever jade MIT https://github.com/visionmedia/jade jquery-ui MIT https://github.com/jquery/jquery-ui jquery MIT https://github.com/jquery/jquery jsnlog-nodejs Apache 2.0 https://github.com/mperdeck/jsnlog-nodejs jsnlog Apache 2.0 https://github.com/mperdeck/jsnlog.js lodash MIT https://github.com/lodash/lodash material-design-icons CC-BY-4.0 https://github.com/google/material-design-icons moment MIT https://github.com/moment/moment
    [Show full text]
  • Rapid Prototyping with JS Agile Javascript Development
    Rapid Prototyping with JS Agile JavaScript Development Azat Mardan This book is for sale at http://leanpub.com/rapid-prototyping-with-js This version was published on 2015-05-05 This is a Leanpub book. Leanpub empowers authors and publishers with the Lean Publishing process. Lean Publishing is the act of publishing an in-progress ebook using lightweight tools and many iterations to get reader feedback, pivot until you have the right book and build traction once you do. ©2012 - 2015 Azat Mardan Tweet This Book! Please help Azat Mardan by spreading the word about this book on Twitter! The suggested tweet for this book is: I’ve downloaded Rapid Prototyping with JS — book on JavaScript and Node.js by @azat_co #RPJS @RPJSbook The suggested hashtag for this book is #RPJS. Find out what other people are saying about the book by clicking on this link to search for this hashtag on Twitter: https://twitter.com/search?q=#RPJS Also By Azat Mardan Oh My JS JavaScript and Node FUNdamentals Introduction to OAuth with Node.js ProgWriter [programmer + writer] Быстрое Прототипирование с JS ProgWriter 2.0: Beyond Books 5 Hacks to Getting the Job of Your Dreams to Live a Happier and Healthier Life Contents 1. Intro to Backbone.js ........................................... 1 1.1 Setting up Backbone.js App from Scratch ............................. 1 1.1.1 Dependencies ........................................ 1 1.2 Working with Collections ..................................... 6 1.3 Event Binding ........................................... 11 1.4 Views and Subviews with Underscore.js ............................. 16 1.5 Refactoring ............................................. 24 1.6 AMD and Require.js for Development .............................. 31 1.7 Require.js for Production ....................................
    [Show full text]
  • Node Is All About 2
    Web Application Development Produced David Drohan ([email protected]) by Department of Computing & Mathematics Waterford Institute of Technology http://www.wit.ie PART 1 SERVER SIDE JAVASCRIPT Outline 1. Introduction – What Node is all about 2. Events – Nodes Event-Driven, Non-Blocking I/O model 3. Node Modules – The Building Blocks of Node 4. Express – A Framework for Node 5. REST – The Architectural Style of the Web 6. API Design – Exposing Application Functionality 7. REST in Express – Leveraging URLs, URI’s and HTTP 8. Demo – Labs in action 06 NODEJS - PART 1 3 Outline 1. Introduction – What Node is all about 2. Events – Nodes Event-Driven, Non-Blocking I/O model 3. Node Modules – The Building Blocks of Node 4. Express – A Framework for Node 5. REST – The Architectural Style of the Web 6. API Design – Exposing Application Functionality 7. REST in Express – Leveraging URLs, URI’s and HTTP 8. Demo – Labs in action 06 NODEJS - PART 1 4 Introduction WHAT NODE IS ALL ABOUT 06 NODEJS - PART 1 5 Background V8 is an open source JavaScript engine developed by Google. Its written in C/C++ and is used in Google Chrome Browser (and is fast!) Node.js runs on V8. It was created by Ryan Dahl in 2009. Finally out of Beta phase. ◦ Latest LTS (Long Term Support) Version is v6.11.3 (see next Slide) ◦ Latest stable current version is v8.5.0 (nodejs.org) (as at 22/09/17) Is Open Source. It runs well on Linux systems, can also run on Windows systems. It comes with a built-in HTTP server library It has lots of libraries and tools available; even has its own package manager (npm) 06 NODEJS - PART 1 6 Node.js Release Working Group 06 NODEJS - PART 1 7 Node.js Release Working Group 06 NODEJS - PART 1 8 Introduction: Basic In simple words Node.js is ‘server-side JavaScript’.
    [Show full text]
  • Time to Check the Tweets: Harnessing Twitter As a Location-Indexed Source of Big Geodata
    Time to Check the Tweets: Harnessing Twitter as a Location-indexed Source of Big Geodata Thesis Presented in Partial Fulfillment of the Requirements for the Degree Master of Arts in the Graduate School of The Ohio State University By Kiril Vatev, B.S. Graduate Program in Geography The Ohio State University 2013 Thesis Committee: Karl Ola Ahlqvist, Advisor Ningchuan Xiao Copyright by Kiril Vatev 2013 Abstract Twitter, a popular online social network based on the microblogging format, is an important and significant source of both locational and archival data. It lends to a wide range of topics, from predicting the results of political elections, analysis of natural disasters, and tracking of disease epidemics, to studying political movements and protests, notably in cases of protest organization in Moldova and Iran, and recent events in the Arab Spring. However, many obstacles and barriers to entry are posed by Twitter’s system. Twitter has two main ways of obtaining data with different API requirements, and both returning different formats of data. System-wide authentication further complicates the data collection process. This research is based in creating an open-source software package to overcome the difficulties and barriers to obtaining a Twitter dataset, for both programming aficionados and those only interested in the data. The goals of the software are to ease the collection, storage, and future access to those interesting and important datasets. The resulting software package provides ways to drill down into the data through advanced queries not available from Twitter, and retains the data for extended analysis and reference over time.
    [Show full text]
  • Web Development with Mongodb and Node Third Edition
    Web Development with MongoDB and Node Third Edition Build fast web applications for handling any kind of data Bruno Joseph D'mello Mithun Satheesh Jason Krol BIRMINGHAM - MUMBAI Web Development with MongoDB and Node Third Edition Copyright © 2017 Packt Publishing All rights reserved. No part of this book may be reproduced, stored in a retrieval system, or transmitted in any form or by any means, without the prior written permission of the publisher, except in the case of brief quotations embedded in critical articles or reviews. Every effort has been made in the preparation of this book to ensure the accuracy of the information presented. However, the information contained in this book is sold without warranty, either express or implied. Neither the author, nor Packt Publishing, and its dealers and distributors will be held liable for any damages caused or alleged to be caused directly or indirectly by this book. Packt Publishing has endeavored to provide trademark information about all of the companies and products mentioned in this book by the appropriate use of capitals. However, Packt Publishing cannot guarantee the accuracy of this information. First published: September 2014 Second edition: October 2015 Third edition: September 2017 Production reference: 1260917 Published by Packt Publishing Ltd. Livery Place 35 Livery Street Birmingham B3 2PB, UK. ISBN 978-1-78839-508-3 www.packtpub.com Credits Authors Copy Editor Bruno Joseph D'mello Charlotte Carneiro Mithun Satheesh Jason Krol Reviewer Project Coordinator Alex Bachuk Sheejal Shah Commissioning Editor Proofreader Smith Thakkar Safis Editing Acquisition Editor Indexer Reshma Raman Rekha Nair Content Development Editor Graphics Jason Pereira Jason Monteiro Technical Editor Production Coordinator Surabhi Kulkarni Melwyn D'sa About the Authors Bruno Joseph D'mello works at Yapsody as a software engineer.
    [Show full text]
  • Backbone-Tutorials.Pdf
    Backbone Tutorials Beginner, Intermediate and Advanced Thomas Davis Backbone Tutorials Beginner, Intermediate and Advanced ©2012 Thomas Davis This version was published on 2012-06-25 This is a Leanpub book, for sale at: http://leanpub.com/backbonetutorials Leanpub helps authors to self-publish in-progress ebooks. We call this idea Lean Publishing. To learn more about Lean Publishing, go to: http://leanpub.com/manifesto To learn more about Leanpub, go to: http://leanpub.com Tweet This Book! Please help Thomas Davis by spreading the word about this book on Twitter! The suggested hashtag for this book is #backbonetutorials. Find out what other people are saying about the book by clicking on this link to search for this hashtag on Twitter: https://twitter.com/search/#backbonetutorials Contents Why do you need Backbone.js? i So how does Backbone.js help? ................................... i Relevant Links ......................................... i Contributors .......................................... i What is a view? ii The “el” property ........................................... ii Loading a template .......................................... iii Listening for events .......................................... iii Tips and Tricks ............................................ iv Relevant Links ......................................... v Contributors .......................................... v What is a model? vi Setting attributes ........................................... vi Getting attributes ..........................................
    [Show full text]
  • Browsercloud.Js - a Federated Community Cloud Served by a P2P Overlay Network on Top of the Web Platform
    browserCloud.js - A federated community cloud served by a P2P overlay network on top of the web platform David Dias Thesis to obtain the Master of Science Degree Telecommunications and Informatics Engineering Examination Committee Chairperson: Prof. Doutor. Paulo Jorge Pires Ferreira Supervisor: Prof. Doutor. Lu´ıs Manuel Antunes Veiga Member of the Committee: Prof. Doutor. Joao˜ Dias Pereira May 2015 Acknowledgements The work here presented is delivered as a final thesis report at Lisbon Tech, University of Lis- bon, Portugal. This thesis is part of a 2 years master programme with focus on peer-to-peer networks, cloud computing and mobile applications. I want to show my appreciation for all the support given from my family, specially to my father, who has worked hard his entire life, even with all the challenges that were presented, to enable me and my sister to go through college. He taught me that preseverance, honesty and humility trumps every challenge, that we never give up. To my friends, Camille Coyac, Nuno Job, Adam Brault, Diogo Monica,´ Pedro Teixeira, Thiago Dantas, Ben Acker, Liliana Angeloˆ and Andre´ Albuquerque, I deeply thank you for being such an inspiring force through my life, for believing and showing interest, providing guidance and for being present in times of need. A special thank you to my professor and thesis coordinator, Lu´ıs Veiga, who has proven to be one of the most interesting humans I’ve met and with always amazing, rapid and open minded interest and feedback to the work we developed during the master thesis. I also want to show my appreciation to all the people that appeared during this journey, that through their presence or an informal conversation, have contributed to the success of this work, these are: Feross Aboukhadijeh, Adam Baldwin, Ilya Gregorik, Phillip Hancke, Igor Soarez, Bernardo Simoes,˜ Philip Roberts and Nathan Fritz.
    [Show full text]
  • Node.Js Recipes Node.Js Recipes Is Your One-Stop Reference for Learning How to Solve Node.Js Prob- Lems
    BOOKS FOR PROFESSIONALS BY PROFESSIONALS® Gackenheimer RELATED Node.js Recipes Node.js Recipes is your one-stop reference for learning how to solve Node.js prob- lems. Node.js is the de facto framework for building JavaScript-powered serv- ers. You will first be introduced to this exciting technology and what it can do, then learn through comprehensive and easy-to-follow recipes that use a problem-solution approach. Node.js Recipes teaches you to fully utilize the Node.js API, and leverage existing modules to build truly exciting projects. Because Node.js is written in JavaScript on the server, it is accessible to those who not only relish in server-side programming but also web developers who understand the ubiquitous language of the web. Node.js Recipes covers all the essential ingredi- ents required to become a seasoned Node.js developer in no time - become a Node. js pro today! Shelve in ISBN 978-1-4302-6058-5 Web Development/General User level: Intermediate 9 781430260585 SOURCE CODE ONLINE www.apress.com For your convenience Apress has placed some of the front matter material after the index. Please use the Bookmarks and Contents at a Glance links to access them. Contents at a Glance About the Author ............................................................................................................. xxiii About the Technical Reviewers ........................................................................................ xxv Acknowledgments .........................................................................................................
    [Show full text]
  • Getting MEAN with Mongo, Express, Angular, and Node
    SAMPLE CHAPTER MANNING Simon Holmes Getting MEAN with Mongo, Express, Angular, and Node by Simon Holmes Chapter 1 Copyright 2016 Manning Publications brief contents PART 1SETTING THE BASELINE .................................................1 1 ■ Introducing full-stack development 3 2 ■ Designing a MEAN stack architecture 24 PART 2BUILDING A NODE WEB APPLICATION...........................51 3 ■ Creating and setting up a MEAN project 53 4 ■ Building a static site with Node and Express 80 5 ■ Building a data model with MongoDB and Mongoose 120 6 ■ Writing a REST API: Exposing the MongoDB database to the application 160 7 ■ Consuming a REST API: Using an API from inside Express 202 PART 3ADDING A DYNAMIC FRONT END WITH ANGULAR.........241 8 ■ Adding Angular components to an Express application 243 v vi BRIEF CONTENTS 9 ■ Building a single-page application with Angular: Foundations 276 10 ■ Building an SPA with Angular: The next level 304 PART 4MANAGING AUTHENTICATION AND USER SESSIONS......347 11 ■ Authenticating users, managing sessions, and securing APIs 349 Introducing full-stack development This chapter covers ■ The benefits of full-stack development ■ An overview of the MEAN stack components ■ What makes the MEAN stack so compelling ■ A preview of the application we’ll build throughout this book If you’re like me then you’re probably impatient to dive into some code and get on with building something. But let’s take a moment first to clarify what is meant by full-stack development, and look at the component parts of the stack to make sure you understand each. When I talk about full-stack development, I’m really talking about developing all parts of a website or application.
    [Show full text]