5 minute guide to deploying your first application using Firebase CloudStore [How-to]
A beginner guide to building your first application using Firebase CloudStore. Everything you need to know about Firestore. And understanding Collections & Documents on Firestore.
Subscribe to our awesome Newsletter.
Today, Google launched a new add-on to one of it’s flagship product Firebase called Firestore, which is a new NoSQL database that can be used with any existing or new Firebase application. But now the question rises that while Firebase is already a Realtime Database why do we need a new add-on for NoSQL database? And the reason for it is that earlier for building a complex application like CRM or a social networking website using Firebase real-time database it turns out to be such a pain that you can’t build complex queries. Right now with Firestore its much easier and powerful and you don’t have to do a lot of denormalizing anymore.
I’ll explain the complex queries, searching and other advanced features in the upcoming articles, while this article will be focused on understanding the basics.
Terminologies
There are two important things you need to know before jumping into Firestore, they are the Collections and Documents.
1. Collections
Collections are the containers for documents and it will always hold documents and never can hold data.
2. Documents
Documents hold the actual data and are contained in collections. It supports various types of data which are listed here.
The Setup
In order to use Firestore you need to import the library.
Via CND
|
|
Via NPM
1
| require("firebase/firestore"); |
Once imported initialize the application with the configuration data from Firebase console
Initialize
|
|
Let’s create a Simple TODO application As usual for getting started let’s start with the traditional example of a todo application. Here we need the following elements,
- A Textbox
- A Button for submitting
- A list for listing all todos
Let’s go ahead and create them.
Todo Form
|
|
Todo List Element
|
|
Now let’s create the corresponding DOM objects and listeners for these elements
Defining the DOM elements
|
|
Attaching a listener function
|
|
Here the handleSubmit
will be the function that will listener when the button is clicked or textbox values are changed.
Setup Firestore Ref
To access a collection in Firestore is almost similar to Firebase real-time database, you need to create a ref object and with it you can access the data.
1
| const todoRef = firebase.firestore().collection("todos"); |
Listener Function
|
|
In the above code once the validations complete we’re creating the todo in Firestore with the function called .add()
You need pass the todo object for the add
function and it returns a promise so you can use then
and catch
to find if success or not.
Listing the todos
To fetch all the todos we can use the same ref variable and use get()
method to get all the documents inside the todo
collection. But inorder to listen to updates we need to use onSnapshot
method which is similar to on()
method in Firebase real-time database.
|
|
As you can see in the above code we’re listening to changes in the ref and when ever we get an update we’re clearing the list and relisting it. Also we’ve used a small ordering query to order by the created at time, which was not possible with realtime database, you can do a lot more things with it which I’ll be covering in the next articles.
Also here unlink Realtime DB we’re getting ID instead of key as the unique value. Once I get each todo I’m adding it to the list with a title and a checkbox, also attaching a listener for checkbox’s change event which is used to update the status.
Now in order to update the status of the todo we use the below function.
|
|
Now this gets you a complete example of a very simple todo. In my next article I’ll write about how to use cloud function triggers for Firestore, managing multiple collections, and more advanced queries.
I feel that Firebase is now a much more matured product than earlier.
Also do checkout our other articles on Firebase here: