Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Conferences
Free Learning
Arrow right icon
Build Applications with Meteor
Build Applications with Meteor

Build Applications with Meteor: Isomorphic JavaScript web development

eBook
AU$14.99 AU$53.99
Paperback
AU$67.99
Subscription
Free Trial
Renews at AU$24.99p/m

What do you get with eBook?

Product feature icon Instant access to your Digital eBook purchase
Product feature icon Download this book in EPUB and PDF formats
Product feature icon Access this title in our online reader with advanced features
Product feature icon DRM FREE - Read whenever, wherever and however you want
OR
Modal Close icon
Payment Processing...
tick Completed

Billing Address

Table of content icon View table of contents Preview book icon Preview Book

Build Applications with Meteor

Building a Shopping Cart

In this chapter, we will build a simple create, read, update, and delete (CRUD) application that will allow the user to add items to a shopping cart, remove them, update the quantity of each item, and track the total price of all added items. This is not, by any means, an e-commerce app but a brief overview of data handling with Meteor. For the frontend view layer, we will use React; also, we will take advantage of Meteor's reactive data package react-meteor-data to handle all the data changes and the dynamic rendering.

First, we will start with a very basic CRUD implementation and, moving forward, we'll refactor the app with the introduction of more concepts.

Here's what this chapter covers:

  • An overview of basic project structures and installation of the required packages
  • An overview of the application architecture
  • Inserting sample data in MongoDB
  • Implementation of...

Creating the project structure

Ctrl + Alt + T will open the terminal, change the directory to the desired location, create a shopping cart app with the meteor CLI, and install all the required packages.

Copy the following commands serially to create the app and install the packages:

>> meteor create shopping_cart
>> npm install
>> npm install react --save
>> npm install react-dom --save
>> meteor add react-meteor-data
>> npm install --save react react-addons-pure-render-mixin

Starting from the client side, let's delete all the default folders and create the following files and folders:

How to structure your app is completely up to you. For quick prototypes, you can use the defaults and just add more into the directories or, if you have a favorite open source project and you like its setup, you can copy the design from it. However, in real life, how the app is architected...

On the server

On the server-side, we have two files: index.js and insertData.js. There is also a private folder where we can define sample data that we can work with. Meteor will treat the private folder as an assets folder and will not bundle it with the rest of the execution code, which makes it a perfect place to have the test data.

In the private folder in file, products.json will have the following fields:

private/products.json

The fields of the Products collection are as follows:

id: This is the product ID.

title: This refers to a product title.

price: This is the price per unit.

inventory: This is the currently available product inventory in the store.

department: This refers to the department ID the product belongs to.

In the root of the application tree, we also have a shared folder where we can have modules used by both the client and the server.

In there, we define the two Collections...

Building the application components

Let's start building the application from top to bottom. The first two entries in the app are the index.html and index.js files. You can name them main.js or app.js or anything you want. I have a preference of naming index (starting with lowercase) as the first entry of any directory in my apps. That said, all React components should be capitalized when you import them; otherwise, React will thread them as HTML tags. To keep it intuitive, you can have the component names and their files' names capitalized.

In the index.html file, we can have our root DOM element:

<head>
<title>Shopping Cart</title>
</head>
<body>
<div id="root"></div>
</body>

We have a pretty simple HTML with only the <head> and <body> tags, and one <div> that will be the root of the parent top-level component, App.

In...

Adding router to the application

In our sample data, we have specified two departments: music and books. Currently, our App parent component renders the products and the cart into a single page.

In Single Page Applications (SPA), most of the time we want to give the user the best user experience by separating parts of the app into pages. The advantages of client site routing are that the user can navigate through different URLs without loading and reloading/refreshing the pages. This great user experience comes with a price. One of the challenges for client routing is the amount of code that the application initially needs to load for all pages. This problem can be solved by splitting the code by pages/routes and lazy loading only those parts of the code for the pages that a user visits.

For this example, we'll use the react-router library to manage the client-side routing:

In total, we have six...

Meteor methods

To make our app work with methods, we need to create tree methods and move all the edits from the client to the server.

Let's place all the methods in a folder called api on the root of the client. The concept of Methods is very similar to Ajax calls to the server:

On the server, we can define them when on the startup:

  Meteor.startup(() => {
….. Methods definition
});
Meteor.methods({
cartInsert: function(product) {
CartCollection.insert({
'title' : product.title,
'price' : product.price,
'inventory' : product.inventory,
'quantity': 1
});
},

In Meteor.methods, we can define all the methods.

Let's start by adding the product method in the cart.

The cartInsert method is the name of the method and, in the body function, we can just copy exactly the same code that we had on the client.

To...

Creating the project structure


Ctrl + Alt + T will open the terminal, change the directory to the desired location, create a shopping cart app with the meteor CLI, and install all the required packages.

Copy the following commands serially to create the app and install the packages:

>> meteor create shopping_cart
>> npm install
>> npm install react --save
>> npm install react-dom --save
>> meteor add react-meteor-data
>> npm install --save react react-addons-pure-render-mixin

Starting from the client side, let's delete all the default folders and create the following files and folders:

How to structure your app is completely up to you. For quick prototypes, you can use the defaults and just add more into the directories or, if you have a favorite open source project and you like its setup, you can copy the design from it. However, in real life, how the app is architected can depend on many factors. Often, we work on a mixture of new and legacy code and sometimes...

On the server


On the server-side, we have two files: index.js and insertData.js. There is also a private folder where we can define sample data that we can work with. Meteor will treat the private folder as an assets folder and will not bundle it with the rest of the execution code, which makes it a perfect place to have the test data.

In the private folder in file, products.json will have the following fields:

private/products.json

The fields of the Products collection are as follows:

id: This is the product ID.

title: This refers to a product title.

price: This is the price per unit.

inventory: This is the currently available product inventory in the store.

department: This refers to the department ID the product belongs to.

In the root of the application tree, we also have a shared folder where we can have modules used by both the client and the server.

In there, we define the two Collections that we will be using: Products and Cart:

export const ProductsCollection = new Mongo.Collection('products...
Left arrow icon Right arrow icon

Key benefits

  • Develop a set of real-world applications each exploring different features of Meteor
  • Make your app more appealing by adding reactivity and responsiveness to it
  • Work with the most powerful feature of Meteor—the “full stack reactivity”—through building real-time applications with many third party libraries

Description

This book starts with the basic installation and overview of the main components in Meteor. You’ll get hands-on multiple versatile applications covering a wide range of topics from adding a front-end views with the hottest rendering technology React to implementing a microservices oriented architecture.All the code is written with ES6/7 which is the latest significantly improved JavaScript language. We’ll also look at real-time data streaming, server to server data exchange, responsive styles on the front-end, full-text search functionality, and integration of many third-party libraries and APIs using npm. By the end of the book, you’ll have the skills to quickly prototype and even launch your next app idea in a matter of days.

Who is this book for?

If you are a developer who is looking forward to taking your application development skills with Meteor to next level by getting your hands-on different projects, this book is for you.

What you will learn

  • See how Meteor fits in the modern web application development by using its reactive data system
  • Make your front-end behave consistently across environments by implementing a predictable state container with Redux
  • Get familiar with React and overview of Angular 2
  • Add a map to your application with a real-time geolocation
  • Plugin into Meteor social media APIs like Twitter's streaming and Facebook's Messenger
  • Add search functionality from scratch to your existing app and data
  • Add responsiveness with Bootstrap 4 and Google's Material Design using Less and Sass
  • Distribute your data across machines and data centers by adding Apache Cassandra to your existing stack.
  • Learn how to scale your microservices with the high performant language neutral framework gRPC.
  • Learn how to query multiple data sources using GraphQL.

Product Details

Country selected
Publication date, Length, Edition, Language, ISBN-13
Publication date : May 30, 2017
Length: 388 pages
Edition : 1st
Language : English
ISBN-13 : 9781787124738
Languages :
Tools :

What do you get with eBook?

Product feature icon Instant access to your Digital eBook purchase
Product feature icon Download this book in EPUB and PDF formats
Product feature icon Access this title in our online reader with advanced features
Product feature icon DRM FREE - Read whenever, wherever and however you want
OR
Modal Close icon
Payment Processing...
tick Completed

Billing Address

Product Details

Publication date : May 30, 2017
Length: 388 pages
Edition : 1st
Language : English
ISBN-13 : 9781787124738
Languages :
Tools :

Packt Subscriptions

See our plans and pricing
Modal Close icon
AU$24.99 billed monthly
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Simple pricing, no contract
AU$249.99 billed annually
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Choose a DRM-free eBook or Video every month to keep
Feature tick icon PLUS own as many other DRM-free eBooks or Videos as you like for just AU$5 each
Feature tick icon Exclusive print discounts
AU$349.99 billed in 18 months
Feature tick icon Unlimited access to Packt's library of 7,000+ practical books and videos
Feature tick icon Constantly refreshed with 50+ new titles a month
Feature tick icon Exclusive Early access to books as they're written
Feature tick icon Solve problems while you work with advanced search and reference features
Feature tick icon Offline reading on the mobile app
Feature tick icon Choose a DRM-free eBook or Video every month to keep
Feature tick icon PLUS own as many other DRM-free eBooks or Videos as you like for just AU$5 each
Feature tick icon Exclusive print discounts

Frequently bought together


Stars icon
Total AU$ 252.97
Meteor: Full-Stack Web Application Development
AU$116.99
Build Applications with Meteor
AU$67.99
React Native Blueprints
AU$67.99
Total AU$ 252.97 Stars icon
Banner background image

Table of Contents

9 Chapters
Foundation of Meteor Chevron down icon Chevron up icon
Building a Shopping Cart Chevron down icon Chevron up icon
Style Your React Components with Bootstrap and Material Design Chevron down icon Chevron up icon
Real-Time Twitter Streaming Chevron down icon Chevron up icon
Developing Kanban Project Management Tool Chevron down icon Chevron up icon
Building a Real-Time Search Application Chevron down icon Chevron up icon
Real-Time Maps Chevron down icon Chevron up icon
Build a Chatbot with Facebook’s Messenger Platform Chevron down icon Chevron up icon
Build Internet of Things Platform Chevron down icon Chevron up icon

Customer reviews

Rating distribution
Full star icon Full star icon Full star icon Full star icon Empty star icon 4
(3 Ratings)
5 star 66.7%
4 star 0%
3 star 0%
2 star 33.3%
1 star 0%
Julien Jul 23, 2017
Full star icon Full star icon Full star icon Full star icon Full star icon 5
This book not only cover Meteor. You're going to learn how to develop professional app along to the best web technologies, from Bootstrap to gRPC.The first chapters are more about how Meteor works and deals with other libraries.Chapter after chapter, this book cover several technologies to help you choose the best ones for your needs.Actually this book is for both Meteor developers and full-stack web developer enthusiast.In spite of some typos, everything is clear and well explained. The book contains lots of exercises that you are encouraged to do to put in practice concepts previously seen.I'm happy to have this book in my library.
Amazon Verified review Amazon
Barnhardt Enterprises, Inc Nov 22, 2019
Full star icon Full star icon Full star icon Full star icon Full star icon 5
Very detailed and well written. This is a great reference for Meteor developers as well as beginners.
Amazon Verified review Amazon
Justin R McCormick Oct 17, 2018
Full star icon Full star icon Empty star icon Empty star icon Empty star icon 2
I bought this book off the 5-star review and figured it would jump start development with meteor. After going through the first few chapters, I am moving onto the next possible candidate. Most of the source code examples don't work, have typos, and missing end of lines. As well as the source examples being wrong, the source examples are not presented clearly by chopping newline's into the next line of the book etc. I'm not sure if this was a printing error, but it started to become a pain.Overall, this was a brief overview for different sections and I would continue reading if the examples weren't chopped & screwed (remix) in a way. After looking at other books, I clearly recommend going with something else. Just my two cents. Trying to save someone the time of buying this unless code examples that don't work will not bother you.
Amazon Verified review Amazon
Get free access to Packt library with over 7500+ books and video courses for 7 days!
Start Free Trial

FAQs

How do I buy and download an eBook? Chevron down icon Chevron up icon

Where there is an eBook version of a title available, you can buy it from the book details for that title. Add either the standalone eBook or the eBook and print book bundle to your shopping cart. Your eBook will show in your cart as a product on its own. After completing checkout and payment in the normal way, you will receive your receipt on the screen containing a link to a personalised PDF download file. This link will remain active for 30 days. You can download backup copies of the file by logging in to your account at any time.

If you already have Adobe reader installed, then clicking on the link will download and open the PDF file directly. If you don't, then save the PDF file on your machine and download the Reader to view it.

Please Note: Packt eBooks are non-returnable and non-refundable.

Packt eBook and Licensing When you buy an eBook from Packt Publishing, completing your purchase means you accept the terms of our licence agreement. Please read the full text of the agreement. In it we have tried to balance the need for the ebook to be usable for you the reader with our needs to protect the rights of us as Publishers and of our authors. In summary, the agreement says:

  • You may make copies of your eBook for your own use onto any machine
  • You may not pass copies of the eBook on to anyone else
How can I make a purchase on your website? Chevron down icon Chevron up icon

If you want to purchase a video course, eBook or Bundle (Print+eBook) please follow below steps:

  1. Register on our website using your email address and the password.
  2. Search for the title by name or ISBN using the search option.
  3. Select the title you want to purchase.
  4. Choose the format you wish to purchase the title in; if you order the Print Book, you get a free eBook copy of the same title. 
  5. Proceed with the checkout process (payment to be made using Credit Card, Debit Cart, or PayPal)
Where can I access support around an eBook? Chevron down icon Chevron up icon
  • If you experience a problem with using or installing Adobe Reader, the contact Adobe directly.
  • To view the errata for the book, see www.packtpub.com/support and view the pages for the title you have.
  • To view your account details or to download a new copy of the book go to www.packtpub.com/account
  • To contact us directly if a problem is not resolved, use www.packtpub.com/contact-us
What eBook formats do Packt support? Chevron down icon Chevron up icon

Our eBooks are currently available in a variety of formats such as PDF and ePubs. In the future, this may well change with trends and development in technology, but please note that our PDFs are not Adobe eBook Reader format, which has greater restrictions on security.

You will need to use Adobe Reader v9 or later in order to read Packt's PDF eBooks.

What are the benefits of eBooks? Chevron down icon Chevron up icon
  • You can get the information you need immediately
  • You can easily take them with you on a laptop
  • You can download them an unlimited number of times
  • You can print them out
  • They are copy-paste enabled
  • They are searchable
  • There is no password protection
  • They are lower price than print
  • They save resources and space
What is an eBook? Chevron down icon Chevron up icon

Packt eBooks are a complete electronic version of the print edition, available in PDF and ePub formats. Every piece of content down to the page numbering is the same. Because we save the costs of printing and shipping the book to you, we are able to offer eBooks at a lower cost than print editions.

When you have purchased an eBook, simply login to your account and click on the link in Your Download Area. We recommend you saving the file to your hard drive before opening it.

For optimal viewing of our eBooks, we recommend you download and install the free Adobe Reader version 9.