Mobile Development

React Native and PWA: Two Powerful Technologies for Building Cross-Platform Mobile Apps

Both React Native (RN) and Progressive Web Apps (PWA) serve the same purpose: to provide a mobile experience for consumers fast and at a relatively low cost. However, they are not identical and have specific features that make them a perfect fit to meet some business needs but a rather poor option to meet others. […]

thumbnail

Both React Native (RN) and Progressive Web Apps (PWA) serve the same purpose: to provide a mobile experience for consumers fast and at a relatively low cost. However, they are not identical and have specific features that make them a perfect fit to meet some business needs but a rather poor option to meet others.

Which technology to pick for your particular project, then? We have prepared some guidelines to address this dilemma.

MVP

React Native and PWA are good for buidling MVPs

RN has a big community and a lot of UI Frameworks, so you can quickly put an app together. This makes the technology a good candidate for building an MVP (Minimum Viable Product) to validate a hypothesis and decide if a full-scale mobile app is worth investing money in. Read one of our posts for an explanation of what an MVP is and what benefits it provides to businesses.

In essence, a PWA is nothing more than a standard website built by using web technologies (CSS, HTML, and JavaScript) with the addition of service workers. Thus, it can also be used to develop an MVP with limited functionality. Later, it can be extended with other features if the validity of the idea has been confirmed.

Therefore, as far as an MVP is concerned, you can go both ways.

Hardware

One of the weaknesses of PWAs is their limited ability to make use of all the features of the devices where they are installed. Currently, a PWA can only access some functionalities such as the camera, microphone, gyroscope, and accelerometer. That, however, is pretty much what it can get hold of.

In this respect, React Native development clearly wins since it can leverage the power of native APIs to access a larger number of hardware features. Need to put a sensor or Bluetooth to work? Use NFC? Then, RN is definitely what you need.

Integration with Third-Party Services

RN can take advantage of a host of external libraries for any of your purposes. Testing, collecting analytical data, communicating with smartwatches or other wearables — RN can do all of that and more. In addition, it integrates well with social media and can switch among the device’s owner’s accounts with no need to enter credentials.

This is not the case with PWAs. Logging into a Twitter account through a Google account, for instance, is out of the question with a PWA. You have to go through the standard authorization routine: typing in a username and password.

This makes RN slightly better than the other technology from the user experience perspective.

Look and Feel

Again, a PWA represents an ordinary website with some features of a mobile app (gesture control, push notifications, and others). That means its user interface is inferior to what native mobile apps can offer. A PWA is also not as convenient to use as a standard mobile app.

An app based on React Native is a different matter since it works with the native widgets of the two major MOSs (Mobile Operating Systems). Thus, the JavaScript code written by a React Native developer can be converted into native code. The result? A fast operation speed and a look and feel that make a React Native app almost indistinguishable from its purely native counterparts.

Search Engine Visibility

If you want your audience to find your blog, e-commerce site, or image gallery on the Internet, PWA has an edge over React Native. This is because the former resides on a server and can be viewed via an ordinary browser. Therefore, Yahoo! and the like can find and index its pages just like they do for normal websites.

React Native apps, in their turn, are similar to native mobile apps. They have to be added to the app stores, downloaded to a user’s device, and installed. Search engines are not “interested” in them.

Stores

As you know, PWAs can be accessed and installed right through a browser. Developers can also upload them to the app stores just like native mobile apps. That said, Apple has built a high wall for PWAs that even top-level professionals find difficult to surmount. Thus, you can only safely bet on the Play Store when it comes to publishing a PWA.

Adding a RN app to the app stores s is not such an arduous task. If the presence in the app stores is important for your business, then choose RN.

Budget

Building a PWA is straightforward for any front-end professional. The basic web technologies plus writing a service worker script — this is all that is required to have an up-and-running progressive web application quickly. Thus, the development cost is much cheaper than that of a native mobile app and even cheaper than that of a React Native app.

React Native may require a developer to write code in Swift/Objective-C or Java/Kotlin to access some of the device’s functionality. This will inevitably lead to an increase in the overall bill. However, it largely depends on the complexity of the app you want to build.

Working with No Internet Connection

A well-known feature of PWAs is the ability to work even when the Internet connection is off or when the network signal is very weak. This is possible thanks to an advanced caching mechanism. Thus, users can continue to read posts, for example, or browse a product catalog.

React Native can work in the autonomous mode too. This calls for installing a third-party library like this one since React Native only comes equipped with the NetInfo module. The latter simply detects whether the Internet is on and is sufficient for quite small projects only. With an external library installed, a React Native app can function properly regardless of the availability of an Internet connection.

Push Notifications

Push notifications are an excellent way to stay connected with your audience. Both PWAs and React Native apps support this functionality. The react-native-push-notification library allows developers to add several types of notifications to their apps. Those will work well both on iOS and Android.

When it comes to PWAs, though, iOS puts spokes in their wheels. For example, Safari favors Apple’s own push notifications service and blocks others, including push notifications from PWAs. So, React Native is preferable in this respect.

The main features of PWA and React Native

Conclusion

The technologies described in this post are different in their features and capabilities. We can’t say that one is better than the other, though. What matters most is your business objectives and how much money you can invest in development.

Just go over the points we’ve highlighted above and decide which of them are essential in your case. If you have any questions related to React Native or PWAs, the GetDevDone developers will be happy to give you all the advice and guidance you might need. Talk to us today!