Build Mobile Apps with Ionic 4 and Firebase: Hybrid Mobile App Development
By Fu Cheng
()
About this ebook
Leverage your existing web development skills to learn the whole cycle of hybrid mobile app development. This edition is fully updated with the changes in Ionic 4, including Stencil, a new framework based on the web components standard. It explains Ionic and Firebase in detail, including how to create hybrid mobile apps using using React and Vue, and run those apps in an internal browser using a wrapper created by Apache Cordova.
Build Mobile Apps with Ionic 4 and Firebase shows you how to focus on developing front-end code, without needing to manage any back-end code or servers. You'll learn in the context of building a Hacker News client app, which can view top stories in Hacker News, view comments of a story, and add stories to favorites.
Explore how Ionic 4 uses Angular as the JavaScript framework to easily develop apps using an interface similar to native apps, and how to access Firebase, a real-time database, inweb apps using JavaScript.
What You'll Learn- Create content-based Ionic mobile apps
- Work with new Ionic 4 compnents like gesture, text, and keyboard controller
- Manage your apps with RxJS & Redux
Front-end developers and mobile app developers
Related to Build Mobile Apps with Ionic 4 and Firebase
Related ebooks
Hands-On Reactive Programming in Spring 5: Build cloud-ready, reactive systems with Spring 5 and Project Reactor Rating: 0 out of 5 stars0 ratingsMastering Spring 5: An effective guide to build enterprise applications using Java Spring and Spring Boot framework, 2nd Edition Rating: 0 out of 5 stars0 ratingsHybrid Mobile Development with Ionic Rating: 0 out of 5 stars0 ratingsPhoneGap and AngularJS for Cross-platform Development Rating: 0 out of 5 stars0 ratingsCreating iOS apps with Xcode: Learn how to develop your own app (English Edition) Rating: 0 out of 5 stars0 ratingsBuilding Kotlin Applications: A comprehensive guide for Android, Web, and Server-Side Development (English Edition) Rating: 0 out of 5 stars0 ratingsGetting Started with Ionic Rating: 0 out of 5 stars0 ratingsPhoneGap for Enterprise Rating: 0 out of 5 stars0 ratingsFull Stack iOS Development with Swift and Vapor: Full stack iOS development made easy (English Edition) Rating: 0 out of 5 stars0 ratingsReact Projects: Build 12 real-world applications from scratch using React, React Native, and React 360 Rating: 0 out of 5 stars0 ratingsGolang for Jobseekers: Unleash the power of Go programming for career advancement (English Edition) Rating: 0 out of 5 stars0 ratingsIonic Cookbook Rating: 0 out of 5 stars0 ratingsIntroducing Spring Framework: A Primer Rating: 0 out of 5 stars0 ratingsPractical Android: 14 Complete Projects on Advanced Techniques and Approaches Rating: 0 out of 5 stars0 ratingsBuilding Progressive Web Applications with Vue.js: Reliable, Fast, and Engaging Apps with Vue.js Rating: 0 out of 5 stars0 ratingsLearning Ionic Rating: 0 out of 5 stars0 ratingsFull Stack Development with Spring Boot and React: Build modern and scalable web applications using the power of Java and React Rating: 0 out of 5 stars0 ratingsFull Stack Development with Spring Boot 3 and React: Build modern web applications using the power of Java, React, and TypeScript Rating: 0 out of 5 stars0 ratingsAngular 6 by Example: Get up and running with Angular by building modern real-world web apps, 3rd Edition Rating: 0 out of 5 stars0 ratingsOpa Application Development Rating: 0 out of 5 stars0 ratingsImplementing AppFog Rating: 0 out of 5 stars0 ratings
Programming For You
Excel 101: A Beginner's & Intermediate's Guide for Mastering the Quintessence of Microsoft Excel (2010-2019 & 365) in no time! Rating: 0 out of 5 stars0 ratingsHTML & CSS: Learn the Fundaments in 7 Days Rating: 4 out of 5 stars4/5Coding All-in-One For Dummies Rating: 4 out of 5 stars4/5Learn to Code. Get a Job. The Ultimate Guide to Learning and Getting Hired as a Developer. Rating: 5 out of 5 stars5/5SQL QuickStart Guide: The Simplified Beginner's Guide to Managing, Analyzing, and Manipulating Data With SQL Rating: 4 out of 5 stars4/5Python Programming : How to Code Python Fast In Just 24 Hours With 7 Simple Steps Rating: 4 out of 5 stars4/5HTML in 30 Pages Rating: 5 out of 5 stars5/5SQL All-in-One For Dummies Rating: 3 out of 5 stars3/5C Programming For Beginners: The Simple Guide to Learning C Programming Language Fast! Rating: 5 out of 5 stars5/5Excel : The Ultimate Comprehensive Step-By-Step Guide to the Basics of Excel Programming: 1 Rating: 5 out of 5 stars5/5Python: For Beginners A Crash Course Guide To Learn Python in 1 Week Rating: 4 out of 5 stars4/5JavaScript All-in-One For Dummies Rating: 5 out of 5 stars5/5C# Programming from Zero to Proficiency (Beginner): C# from Zero to Proficiency, #2 Rating: 0 out of 5 stars0 ratingsGrokking Algorithms: An illustrated guide for programmers and other curious people Rating: 4 out of 5 stars4/5PYTHON: Practical Python Programming For Beginners & Experts With Hands-on Project Rating: 5 out of 5 stars5/5Linux: Learn in 24 Hours Rating: 5 out of 5 stars5/5SQL: For Beginners: Your Guide To Easily Learn SQL Programming in 7 Days Rating: 5 out of 5 stars5/5Python QuickStart Guide: The Simplified Beginner's Guide to Python Programming Using Hands-On Projects and Real-World Applications Rating: 0 out of 5 stars0 ratingsBeginning Programming with C++ For Dummies Rating: 4 out of 5 stars4/5Coding with JavaScript For Dummies Rating: 0 out of 5 stars0 ratingsLearn PowerShell in a Month of Lunches, Fourth Edition: Covers Windows, Linux, and macOS Rating: 5 out of 5 stars5/5
Reviews for Build Mobile Apps with Ionic 4 and Firebase
0 ratings0 reviews
Book preview
Build Mobile Apps with Ionic 4 and Firebase - Fu Cheng
© Fu Cheng 2018
Fu ChengBuild Mobile Apps with Ionic 4 and Firebasehttps://doi.org/10.1007/978-1-4842-3775-5_1
1. Getting Started
Fu Cheng¹
(1)
Sandringham, Auckland, New Zealand
Mobile apps development is a hot topic for both companies and individual developers. You can use various kinds of frameworks and tools to build mobile apps for different platforms. In this book, we use Ionic 4 to build so-called hybrid mobile apps. As the first chapter, this chapter provides the basic introduction of hybrid mobile apps and helps you to set up the local environment for development, debugging, and testing.
After reading this chapter, you should have a basic understanding of how hybrid mobile apps are built and get a local development environment ready to use.
Mobile Apps Refresher
With the prevalence of mobile devices, more and more mobile apps have been created to meet all kinds of requirements. Each mobile platform has its own ecosystem. Developers use SDKs provided by the mobile platform to create mobile apps and sell them on the app store. Revenue is shared between the developers and the platform. Table 1-1 shows the statistics of major app stores at the time of writing.
Table 1-1
Statistics of Major App Stores
The prevalence of mobile apps also creates a great opportunity for application developers and software companies. A lot of individuals and companies make big money on the mobile apps markets. A classic example is the phenomenal mobile game Flappy Bird. Flappy Bird was developed by Vietnam-based developer Dong Nguyen. The developer claimed that Flappy Bird was earning $50,000 a day from in-app advertisements as well as sales. Those successful stories encourage developers to create more high-quality mobile apps.
Let’s now take a look at some key components of mobile app development.
Hybrid Mobile Apps
Developing mobile apps is not an easy task. If you only want to target a single mobile platform, then the effort may be relatively smaller. However, most of the time we want to distribute apps on many app stores to maximize the revenue. To build the kind of apps that can be distributed to various app stores, developers need to use different programming languages, SDKs, and tools: for example, Objective-C/Swift for iOS and Java for Android. We also need to manage different code bases with similar functionalities but implemented using different programming languages. It’s hard to maximize the code reusability and reduce code duplications across different code bases, even for the biggest players in the market. That’s why cross-platform mobile apps solutions, like Xamarin ( https://www.xamarin.com/ ), React Native ( https://facebook.github.io/react-native/ ), RubyMotion ( http://www.rubymotion.com/ ), and Flutter ( https://flutter.io/ ) also receive a lot of attention. All these solutions have a high learning curve for their programming languages and SDKs, which creates a burden for ordinary developers.
Compared to Objective-C/Swift, Java, C#, or Ruby, web development skills – for example, HTML, JavaScript, and CSS are much easier to learn. Building mobile apps with web development skills is made possible by HTML5. This new type of mobile apps is called hybrid mobile apps. In hybrid mobile apps, HTML, JavaScript, and CSS code run in an internal browser (WebView) that is wrapped in a native app. JavaScript code can access native APIs through the wrapper. Apache Cordova ( https://cordova.apache.org/ ) is the most popular open source library to develop hybrid mobile apps.
Compared to native apps, hybrid apps have both their benefits and drawbacks. The major benefit is that developers can use existing web development skills to create hybrid apps and use only one code base for different platforms. By leveraging responsive web design techniques, hybrid apps can easily adapt to different screen resolutions. The major drawback is the performance issues with hybrid apps. As the hybrid app is running inside of an internal browser, the performance of hybrid apps cannot compete with native apps. Certain types of apps, such as games or apps that rely on complicated native functionalities, cannot be built as hybrid apps. But many other apps can be built as hybrid apps.
Before making the decision of whether to go with native apps or hybrid apps, the development team needs to understand the nature of the apps to build. Hybrid apps are suitable for content-centric apps, such as news readers, online forums, or showcasing products. These content-centric apps act like traditional web apps with limited user interactions. Another important factor to consider is the development team’s skill sets. Most apps companies may need to hire both iOS and Android developers to support these two major platforms for native apps. But for hybrid apps, only front-end developers are enough. It’s generally easier to hire front-end developers rather than Java or Swift/Objective-C developers.
Apache Cordova
Apache Cordova is a popular open source framework to develop hybrid mobile apps. It originates from PhoneGap ( http://phonegap.com/ ) created by Nitobi. Adobe acquired Nitobi in 2011 and started to provide commercial services for it. The PhoneGap source code contributed to the Apache Software Foundation and the new project Apache Cordova was started from its code base.
An Apache Cordova application is implemented as a web page. This web page can reference JavaScript files, CSS files, images, and other resources. The key component of understanding how Cordova works is the WebView. WebView is the component provided by native platforms to load and run web pages. Cordova applications run inside the WebViews. A powerful feature of Cordova is its plugin interface, which allows JavaScript code running in a web page to communicate with native components. With the help of plugins, Cordova apps can access a device’s accelerometer, camera, compass, contacts, and more. There are already many plugins available in Cordova’s plugin registry ( http://cordova.apache.org/plugins/ ). We can easily find plugins used for common scenarios.
Apache Cordova is just a runtime environment for web apps on native platforms. It can support any kinds of web pages. To create mobile apps that look like native apps, we need other UI frameworks to develop hybrid mobile apps. Popular choices of hybrid mobile apps UI frameworks include Ionic framework ( http://ionicframework.com/ ), Sencha Touch ( https://www.sencha.com/products/touch/ ), Kendo UI ( http://www.telerik.com/kendo-ui ), and Framework7 ( http://framework7.io/ ). Ionic framework is the one we are going to cover in this book.
Ionic Framework
Ionic framework is a powerful tool to build hybrid mobile apps. It’s open source ( https://github.com/ionic-team/ionic ) and has over 35,000 stars on GitHub, the popular social coding platform. Ionic framework is not the only player in hybrid mobile apps development, but it’s the one that draws a lot of attention and is recommended as the first choice by many developers. Ionic is popular for the following reasons:
Based on Web Components standards and is framework agnostic. Web Components are W3C specifications of components for the web platform. Ionic components are built as custom elements using its own open source tool, Stencil. Being framework agnostic makes Ionic components work with any framework. Developers are free to choose the framework to use, including Angular, React, and Vue.
Provides beautifully designed out-of-box UI components that work across different platforms. Common components include lists, cards, modals, menus, and pop-ups. These components are designed to have a similar look and feel as native apps. With these built-in components, developers can quickly create prototypes with good enough user interfaces and continue to improve them.
Leverages Apache Cordova as the runtime to communicate with native platforms. Ionic apps can use all the Cordova plugins to interact with the native platform. Ionic Native further simplifies the use of Cordova plugins in Ionic apps.
Performs great on mobile devices. The Ionic team devotes great effort to make it perform well on different platforms.
The current release version of Ionic framework is 4.0. Ionic 4 is the first version of Ionic to be framework agnostic. Ionic Core is the set of components based on Web Components. Ionic Angular is the framework binding of Ionic Core with Angular. This book focuses on Ionic Angular with Angular 6.
Apart from the open source Ionic framework, Ionic also provides a complete solution Ionic Pro for mobile app development , which includes the following products:
Ionic Creator – Ionic Creator is a desktop app to create Ionic apps using drag-and-drop. It helps nontechnical users to quickly create simple apps and prototypes.
Ionic View – Ionic View allows viewing Ionic apps shared by others directly on the phones. It’s a great tool for app testing and demonstration.
Ionic Deploy – Ionic Deploy performs hot updates to apps after they are published to app stores.
Ionic Package – Ionic Package builds Ionic apps and generates bundles ready for publishing to app stores. With Ionic Package, we don’t to manage local build systems and can use the cloud service instead.
Ionic Monitor – Ionic Monitor can monitor apps and report runtime errors.
This book also covers usage of these products in Ionic Pro. Ionic Pro offers a free starter plan to try out features provided by Ionic Deploy and Ionic Monitor. With a $29 per month plan, you can access all features in Ionic Pro. Check out the pricing ( https://ionicframework.com/pro/pricing ) of Ionic Pro if you want to know more about it. Another important project to mention is Ionic Capacitor ( https://capacitor.ionicframework.com/ ), which will replace Apache Cordova to build native progressive web apps. Even though Capacitor is out of the scope of this book, it’s still worthwhile to check out this project to see the future of developing hybrid mobile apps with Ionic.
Firebase
Mobile apps usually need back-end services to work with the front-end UI. This means that there should be back-end code and servers to work with mobile apps. Firebase ( https://firebase.google.com/ ) is a cloud service to power apps’ back ends. Firebase can provide support for data storage and user authentication. After integrating mobile apps with Firebase, we don’t need to write back-end code or manage the infrastructure.
Firebase works very well with Ionic to eliminate the pain of maintaining back-end code. This is especially helpful for hybrid mobile apps developers with only front-end development skills. Front-end developers can use JavaScript code to interact with Firebase.
How to Build Mobile Apps
Even with the frameworks and services mentioned above, it’s still not an easy task to build mobile apps. There are multiple stages in the whole development life cycle from ideas to published apps. A typical process may include the following major steps:
Ideas brainstorming. This is when we identify what kind of mobile apps to build. It usually starts from vague ideas and expands to more concrete solutions.
Wire-framing and prototyping. This is when we draw on the whiteboard to identify main usage scenarios. Prototypes may be created to demonstrate core usage scenarios for better communications with stakeholders.
User experiences design. This is when all pages and navigation flows are finalized, and we are now clear what exactly needs to be built.
Implementation. This is when the development team implements the pages to fulfill requirements.
Testing. Unit testing should be part of implementation of pages and components. End-to-end testing is also required to verify all usage scenarios. All these tests should be executed automatically.
Continuous integration. Continuous integration is essential for code quality. If every code commit can be tested automatically, then the development team will be more confident about the product’s quality.
Publishing. This is when the app is published to app stores.
Operations. After the app is published, we still need to continuously monitor its running status. We need to capture errors and crash logs occurred on users’ devices.
This book is a guide to build mobile apps that focuses on implementation and testing. Topics including continuous integration, app publishing, and monitoring are also covered.
Prepare Your Local Development Environment
Before we can build Ionic apps, we first need to set up the local development environment. We’ll need various tools to develop, test, and debug Ionic apps.
Node.js
Node.js is the runtime platform for Ionic CLI. To use Ionic CLI, we first need to install Node.js ( https://nodejs.org/ ) on the local machine. Node.js is a JavaScript runtime built on Chrome’s V8 JavaScript engine. It provides a way to run JavaScript on the desktop machines and servers. Ionic CLI itself is written in JavaScript and executed using Node.js. There are two types of release versions of Node.js – the stable LTS versions and current versions with the latest features. It’s recommended to use Node.js version 6 or greater, especially the latest LTS version (8.12.0 at the time of writing).
Installing Node.js also installs the package management tool npm. npm is used to manage Node.js packages used in projects. Thousands of open source packages can be found in the npmjs registry ( https://www.npmjs.com/ ). If you have background with other programming languages, you may find npm is similar to Apache Maven ( https://maven.apache.org/ ) for Java libraries or Bundler ( http://bundler.io/ ) for Ruby gems.
Ionic CLI
After Node.js is installed, we can use npm to install the Ionic command-line tool and Apache Cordova.
$ npm i -g cordova ionic
Note
You may need to have system administrator privileges to install these two packages. For Linux and macOS, you can use sudo. For Windows, you can start a command-line window as the administrator. However, it’s recommended to avoid using sudo when possible, as it may cause permission errors when installing native packages. Treat this as the last resort. The permission errors usually can be resolved by updating the file permissions of the Node.js installation directory.
Install Ionic CLI Using yarn
yarn ( https://yarnpkg.com/ ) is a fast, reliable, and secure dependency management tool. After Facebook open sourced it, it quickly became popular in the Node.js community as a better alternative to npm. If you want to use yarn, follow the official instructions ( https://yarnpkg.com/en/docs/install ) to install it. After installing yarn, we can use the following command to install Ionic CLI and Cordova.
$ yarn global add cordova ionic
This book still uses npm as the package manager. If you didn’t know about yarn before, read this guide ( https://yarnpkg.com/en/docs/migrating-from-npm ) about how to migrate from npm to yarn. Common yarn commands are listed as below:
yarn add [package] – Add packages as the project’s dependencies. You can provide multiple packages to install. Version requirements can be specified following the Semantic Versioning spec (http://semver.org/). For example, we can use [email protected] to install version 4.17.5 of lodash.
yarn upgrade [package] – Upgrade or downgrade versions of packages.
yarn remove [package] – Remove packages.
yarn global – Manage global dependencies.
The file yarn.lock contains the exact version of all resolved dependencies. This file is to make sure that builds are consistent across different machines . This file should be managed in the source code repository.
Note
yarn and npm are both good package managers for Node.js. It’s hard to choose between these two. Different development teams may have their own preferences. The main reason to use npm for Ionic apps development is that Cordova CLI only supports npm and has no plan to support yarn ( https://github.com/apache/cordova-cli/pull/292#issuecomment-401331607 ). Cordova CLI uses npm to install Cordova plugins. If we use yarn to manage dependencies, then after a Cordova plugin is installed, the existing dependencies in the directory node_modules will be in an inconsistent status, and we need to run yarn again to fix the issue.
After finishing installation of Ionic CLI and Cordova, we can use the command ionic to start developing Ionic apps.
You are free to use Windows, Linux, or macOS to develop Ionic 4 apps. Node.js is supported across different operating systems. One major limitation of Windows or Linux is that you cannot test iOS apps using the emulator or real devices. Some open source Node.js packages may not have the same test coverage on Windows as Linux or macOS. So they are more likely to have compatibility issues when running on Windows. But this should only affect the CLI or other tools, not Ionic 4 itself.
After Ionic CLI is installed, we can run ionic info to print out current runtime environment information and check for any warnings in the output; see Listing 1-1. The output also provides detailed information about how to fix those warnings.
Ionic:
ionic (Ionic CLI) : 4.1.0 (/Users/fucheng/node_modules/ionic)
Ionic Framework : @ionic/angular 4.0.0-beta.12
@angular-devkit/core : 0.8.5
@angular-devkit/schematics : 0.8.5
@angular/cli : 6.2.5
@ionic/ng-toolkit : 1.0.8
@ionic/schematics-angular : 1.0.6
Cordova:
cordova (Cordova CLI) : 8.0.0
Cordova Platforms : android 7.0.0, ios 4.5.4
Cordova Plugins : cordova-plugin-ionic 4.1.7, cordova-plugin-ionic-keyboard 2.0.5, cordova-plugin-ionic-webview 2.0.3, (and 12 other plugins)
System:
Android SDK Tools : 26.1.1
ios-deploy : 1.9.0
ios-sim : 6.1.3
NodeJS : v8.12.0 (/usr/local/bin/node)
npm : 6.4.1
OS : macOS High Sierra
Xcode : Xcode 9.3 Build version 9E145
Environment :
ANDROID_HOME : /Users/fucheng/Library/Android/sdk
Listing 1-1
Output of ionic info
iOS
Developing iOS apps with Ionic requires macOS and Xcode ( https://developer.apple.com/xcode/ ). You need to install Xcode and Xcode command-line tools on macOS. After installing Xcode, you can open a terminal window and type command shown below.
$ xcode-select -p
If you see output like that below, then command-line tools have already been installed.
/Applications/Xcode.app/Contents/Developer
Otherwise, you need to use the following command to install it.
$ xcode-select --install
After the installation is finished, you can use xcode-select -p to verify.
To run Ionic apps on the iOS simulator using Ionic CLI, package ios-sim is required. Another package ios-deploy is also required for deploying to install and debug apps. You can install both packages using the following command.
$ npm i -g ios-sim ios-deploy
Android
To develop Ionic apps for Android, Android SDK must be installed. Before installing Android SDK , you should have JDK installed first. Read this guide ( https://docs.oracle.com/javase/8/docs/technotes/guides/install/ ) about how to install JDK 8 on different platforms. It’s recommended to install Android Studio ( https://developer.android.com/studio/index.html ), which provides a nice IDE and bundled Android SDK tools. If you don’t want to use Android Studio, you can install stand-alone SDK tools.
Note
Android API level 22 is required to run Ionic apps. Make sure that the required SDK platform is installed.
Stand-alone SDK tools is just a ZIP file; unpack this file into a directory and it’s ready to use. The downloaded SDK only contains basic SDK tools without any Android platform or third-party libraries. You need to install the platform tools and at least one version of the Android platform. Run android in tools directory to start Android SDK Manager to install platform tools and other required libraries.
After installing Android SDK, you need to add SDK’s tools and platform-tools directories into your PATH environment variable , so that SDK’s commands can be found by Ionic. Suppose that the SDK tools is unpacked into /Development/android-sdk, then add /Development/android-sdk/tools and /Development/android-sdk/platform-tools to PATH environment variable. For Android Studio, the Android SDK is installed into directory /Users/
To modify PATH environment variable on Linux and macOS, you can edit ~/.bash_profile file to update PATH as shown below. The PATH environment below uses the Android SDK from Android Studio. You can replace it with another directory if stand-alone SDK tools is used.
export PATH=${PATH}/:/Users/
: /Users/
To modify the PATH environment variable on Windows, you can follow the steps below.
1.
Click Start menu, then right-click Computer and select Properties.
2.
Click Advanced System Settings to open a dialog.
3.
Click Environment Variables in the dialog and find PATH variable in the list, then click Edit.
4.
Append the path of tools and platform-tools directories to the end of PATH variable.
It’s highly recommended to use Android Studio instead of stand-alone SDK tools. Stand-alone SDK tools is more likely to have configuration issues.
Genymotion
Genymotion ( https://www.genymotion.com/ ) is a commercial Android emulator with better performance than the standard emulators. It’s recommended to use Genymotion for Android emulation instead of the standard emulators. You can start from the free Genymotion personal edition ( https://www.genymotion.com/fun-zone/ ) to emulate apps.
IDEs and Editors
You are free to use your favorite IDEs and editors when developing Ionic