table of contents

It is 2020, and the phrase “you’ve got the whole world in your hands’ ‘is more relevant than ever before. Most businesses today rely on the power of the internet to ensure that customers around the globe can find and use their products. As mobiles outnumber computers ten to one, most companies now have dedicated apps for the two dominant mobile platforms.

However, this can incur significant development, testing and maintenance costs. Costs for developing mobile apps for each platform and a website are quite high, causing companies to shell out thrice as much (compared to a website) for this task.

Native apps come with the additional workload of App Store SEO, which ensures that your app stays in the top lists, allowing users to find your app quickly. Enter Progressive Web Apps.

Imagine a near-native app-like experience without the hassle of having to visit the app store to install them. Progressive Web Apps provide an experience that is built and delivered directly through the web. For developers, these apps eliminate the headache (and associated costs) of maintaining three different codebases.

What are Progressive Web Apps?

Progressive Web Apps are not a new framework or an entirely new technology – they are applications that follow a set of best practices to ensure that they function like a mobile or a desktop application. The intent of Progressive Web Apps is to provide a user experience that is so similar to native mobile apps that users are unable to tell the difference.

These apps are often deployed using an Add to Home Screen button, which allows users to install the app in the background. This app will now reside in the app drawer, allowing you to have the same experience as the website, but now on your mobile phone. Progressive Web Apps also have an offline mode that lets you browse content available in the app even when you are not connected to the internet. Cool, isn’t it?

What makes a web app a Progressive Web App?

Although there are not too many differences between a web app and a progressive web app, there are some properties a Progressive Web App must exhibit. These include:

Offline content

A PWA must be able to start offline and display meaningful information. In short, it should act like a native Android or iOS app when opened.

Designed for touch

The interface of the app must be designed for touch interfaces which should include gesture interactions. There should be no delays in the response of touch.

Metadata for the app

The app must provide metadata to the browser about the way it should look and feel and provide an icon on the home screen.

Push Notifications

If needed, the app must be able to receive notifications when not running.

Responsiveness

The app must fill the screen like a native mobile app. They should also work for desktop devices the way they do for mobile devices.

Installable

The ability to install an app is a progressive feature. The app must also work as a normal website on platforms that do not support service workers completely, like Safari.

Openness

The app must provide a way to share the current URL and should not be locked to a browser or an app store.

PWAS - Volumetree

 

Why do we need Progressive Web Apps? What are its advantages?

A good case study for Progressive Web Apps would be Twitter’s progressive web app called Twitter Lite.

Why did Twitter need a web app? With hundreds of millions of users, Twitter needed a fast and reliable way to engage them securely on mobiles. With the overheads of native apps becoming prohibitive, Twitter went the Progressive Web App way by creating Twitter Lite and the results were mind-boggling.

With a 70%+ increase in tweets, bounce rate reduction of up to 20%, load time enhancement of 30% and a reduction in data consumption by up to 70% Twitter Lite has proven the prowess of Web Apps to the world. This alone has been the reason Twitter Lite is the default mobile web experience for all Twitter users. Twitter Lite has been a shining example and the poster boy for all Progressive Web App developers around the world.

Progressive apps have many advantages. Some of these include:

Speed and reliability

Progressive web apps use local caches to store and display static assets. This means that in areas with good connectivity you have no problems accessing any web content but in areas with slow internet speeds like 2g, you are left with a website or a native app that does not load.

In progressive Web Apps, the static data is cached ensuring that the app starts up as fast as it did with good connectivity as the data is served from the device itself. This ensures that the app is reliably fast. It fires up the moment you tap it, reducing user frustration because of load times.

Access everywhere

As PWAs are based on HTML5, they can load on any operating system or device if it has a browser. This makes them accessible on almost any platform that can support HTML5 and a browser.

Installable

Most users might skip installing an app if they must visit the app store or an alternative location. Progressive Web Apps can run in a browser but have the additional capability of being installed. These apps look like any other app, launch like native apps and have similar customized splash screens and icons.

This helps them have a unified user experience which is the same as native apps without requiring an app store download. The installation occurs in the background, without the user having to move away from the website.

Engaging
As Progressive Web Apps can send push notifications to users just like native apps, they keep the user engaged and notified within the app.

Cross-Platform

Utilizing the power of responsive design techniques, PWAs work on both mobile and desktop platforms, ensuring that you can share the codebase between them. This allows the developer to reduce overheads associated with developing and testing native apps.

Easy to update

With a single codebase, these apps are extremely easy to update. Users can get the most updated version of the app directly from the source instead of going through the app store and developers can focus on a single codebase which results in fewer bugs and glitches in the app.

SEO

These apps can be promoted using SEO, which makes it easy to find them. If your brand SEO is on point, the app will be there for users to find and use without having to hunt for it in the app store.

Further Reading On Volumetree:

9 Steps to Building a Progressive Web App

Building a Progressive Web App is a straightforward process, but the development process must not be taken lightly. With an experienced development partner like Volumetree, the development process is extremely streamlined, and your app will be ready to go from the first instance itself.

If, however, you wish to develop the app yourself, ensure that you have an experienced development and testing team.
Before you begin, please go through the checklist of items that have been published by Google for Progressive Apps. This will ensure that you have all the essentials in place. Once all that is covered, you can start developing your app.

Here is an overview of the steps you need to undertake to build a basic Progressive Web App. Please note that we have deliberately kept this simple so you can understand how to go about building a Progressive Web App.

In our sample app, we will get the latest trending gif files from the website gfycat.com and display them in our app. These images should also be visible when the user does not have internet connectivity. This satisfies the offline experience requirement of a Progressive Web App.

1. Create your HTML page

This is a prerequisite for your app. A skeleton HTML file for the sake of an example can just have a simplistic H1 tag that prints a line.

A very simplistic page that displays The coolest stuff around today:

<!DOCTYPE html>
<html lang=”en”>
<head>
<meta charset=”UTF-8″>
<title>Get your cool stuff here!</title>
<link rel=”stylesheet” href=”/styles.css”>
</head>
<body>
<header>
<h1 class=”center”>The coolest GIF files around!
<main>
<div class=”container”></div>
</main>
<script src=”application.js”></script>

</body>
</html>

2. Creating the function to fetch cool stuff

Once the HTML has been created, we would need to fetch the data we need to display. This can be accomplished using a fetch function. This function will gather the data to display in your HTML page.

async function fetchCurrentGifs() {
const gifget = await fetch(`https://api.gfycat.com/v1/reactions/populated?tagName=trending?api_key=${apiKey}&limit=10`);
const json = await gifget.json();
main.innerHTML = json.data.map(createStuff).join(‘\n’);
}

Progressive web app development company banner - Volumetree

3. Creating a manifest file

A manifest file is a JSON file that provides meta-information about your app. This app includes information like the icon that will be seen when installed, the color of the app, the name, the short name, etc.

An easy way to make a manifest is to generate the manifest file using a tool We used the Web App Manifest Generator by firebase app to generate our manifest.

{
“name”: “Coolest GIF files around”,
“short_name”: “TopGifs”,
“icons”: [{
“src”: “images/icons/icon-small.png”,
“sizes”: “128×128”,
“type”: “image/png”
}],
“theme_color”: “#2196f3”,
“background_color”: “#2196f3”,
“display”: “browser”,
“scope”: “/”,
“start_url”: “/index.html”
}

Making your app progressive involves adding the path of the manifest file to your skeleton HTML file. This is accomplished using the

<link> element in the <head> of a HTML file.
<link rel=”manifest” href=”/manifest.json”>

4. Adding Icons

The icon is used to display an icon for the app when the user installs the app in their application drawer. A PNG or a JPG will work fine. The tool for manifest generation listed above will help you in generating icons for various formats.

5. Creating a Service Worker

A service worker is an event-driven system that is invoked when an event is triggered during a request. These act as proxies between the network and the application. A service worker can be simply defined as a few lines of JavaScript code that continually run in the background.

Responses of the events like fetch or install can be handled using the fetch event listener in the Service Worker. A service worker must be registered, installed, and activated in a web application for it to start handling fetch and other events. Service workers cache information for our app in the background by intercepting network requests, which is then used to load and display data for offline viewing.

A service worker will aid in caching data and fetching resources. If data exists in the cache, the service worker will send data from the cache. Else, data will be fetched from the URL and served. You can easily think of what functionality you wish to provide when your app is offline and cache requests accordingly. As an example, you may want to cache the images section of your app so that they are available without an internet connection too.

6. Registering the Service Worker

The service worker needs to be registered using the navigator library of the browser. Ensure that you serve the service worker from the root directory and not from /scripts/. This sets the scope for the service worker. With this method, the service worker will control requests from all pages in this domain.

if (‘serviceWorker’ in navigator) {

window.addEventListener(‘load’, function() {

navigator.serviceWorker.register(‘/serviceWorker.js’);

});

}

To check if a service worker has been successfully registered, open your app in the browser, open the console. Now click on Network > Application > Service Workers. If the service worker has loaded, you will see it in this tab.

If the service worker has successfully loaded, you will be able to see stuff even when you’re offline. To test, refresh the page and let it load. Now turn off your internet connection and reload the page. Your data will still be served as the service worker has cached it.

7. Installing the app

Loading your app twice will give the user the option to Add to Home Screen. Once added, the user will be able to launch the app using the app icon selected earlier from the home screen of their device itself.

According to Chrome, to trigger an install prompt an app must have:
· A service worker and HTTPS
· A web app manifest file with basic configuration and with display: standalone
· Have had a minimum of two distinct visits

8. Push Notifications

Push Notifications are an excellent way to engage with and stay in touch with your users. As push notifications do not require the app to be in the foreground, they are a wonderful way to remind users that they have not used your app in a while.

9. Unsupported Browsers

For browsers that do not support Progressive Web Apps like Safari, the alternative is to create an immersive, responsive web experience. However, when Apple decides to add support for PWAs, your app will be ready to rock on that platform too!

As you’ve read until now, creating a very simple, basic Progressive Web App is not that difficult, but does require an experienced developer or a team to help you develop, test and deploy the app. With an experienced development partner like Volumetree, you can take the guesswork out of the equation and ensure that your users are provided an avant-garde app that ticks all the right boxes. Contact us today for a quote or to discuss how we can help you provide a better experience to your users.

post tags :

3,749 Comments

  1. Thomasaroth July 23, 2024 at 1:08 am - Reply
  2. JamesVox July 23, 2024 at 4:45 am - Reply

    ciprofloxacin over the counter: cipro – buy cipro online without prescription

  3. MyronPreot July 23, 2024 at 8:18 am - Reply

    https://ciprodelivery.pro/# п»їcipro generic
    doxycycline 100 mg india [url=https://doxycyclinedelivery.pro/#]doxycycline without a prescription[/url] doxycycline 75 mg price

  4. Thomasaroth July 23, 2024 at 8:57 am - Reply

    http://ciprodelivery.pro/# ciprofloxacin generic price

  5. SightCare reviews July 23, 2024 at 10:36 am - Reply

    Can I just say what a aid to seek out someone who really knows what theyre speaking about on the internet. You undoubtedly know the best way to deliver a difficulty to gentle and make it important. Extra folks must read this and understand this aspect of the story. I cant consider youre no more popular since you definitely have the gift.

  6. Prodentim July 23, 2024 at 12:47 pm - Reply

    I’ve read several good stuff here. Certainly value bookmarking for revisiting. I surprise how much attempt you place to make this kind of great informative site.

  7. JamesVox July 23, 2024 at 5:32 pm - Reply

    where can i buy cheap clomid pill: get cheap clomid for sale – cost of cheap clomid without a prescription

  8. MyronPreot July 23, 2024 at 5:33 pm - Reply

    https://doxycyclinedelivery.pro/# doxycycline 50 mg buy uk
    cipro pharmacy [url=http://ciprodelivery.pro/#]buy cipro online canada[/url] buy cipro cheap

  9. Nkbybj July 23, 2024 at 7:01 pm - Reply

    buy norfloxacin for sale – noroxin brand buy confido generic

  10. hire a hacker dark web July 23, 2024 at 9:55 pm - Reply

    Outstanding post but I was wanting to know if you could write a litte more on this topic? I’d be very thankful if you could elaborate a little bit more. Many thanks!

  11. Neotonics Review July 24, 2024 at 12:46 am - Reply

    Hi there, i read your blog from time to time and i own a similar one and i was just curious if you get a lot of spam feedback? If so how do you prevent it, any plugin or anything you can recommend? I get so much lately it’s driving me mad so any help is very much appreciated.

  12. MyronPreot July 24, 2024 at 3:04 am - Reply

    http://paxloviddelivery.pro/# paxlovid pharmacy
    п»їpaxlovid [url=http://paxloviddelivery.pro/#]paxlovid buy[/url] paxlovid pharmacy

  13. Thomasaroth July 24, 2024 at 7:35 am - Reply

    https://doxycyclinedelivery.pro/# doxycycline antimalarial

  14. MyronPreot July 24, 2024 at 12:44 pm - Reply

    http://doxycyclinedelivery.pro/# doxycycline 20 mg price
    doxycycline 200 [url=http://doxycyclinedelivery.pro/#]doxycycline cap price[/url] how much is doxycycline in south africa

  15. Thomasaroth July 24, 2024 at 3:58 pm - Reply

    https://clomiddelivery.pro/# can you get cheap clomid without a prescription

  16. JamesVox July 24, 2024 at 6:58 pm - Reply

    amoxicillin 500 mg tablet: amoxicillin 500 mg tablets – buy amoxicillin without prescription

  17. JamesVox July 25, 2024 at 7:34 am - Reply

    doxycycline 100mg capsules buy: doxycycline prices – buy doxycycline without prescription

  18. Robertfloar July 27, 2024 at 3:45 pm - Reply

    clomid tablets: how to get generic clomid – how can i get cheap clomid without a prescription

  19. Wtfjiq July 28, 2024 at 10:41 am - Reply

    order generic finasteride – order kamagra 100mg pill buy generic uroxatral for sale

  20. cognicarepro July 28, 2024 at 2:27 pm - Reply

    This is a very good tips especially to those new to blogosphere, brief and accurate information… Thanks for sharing this one. A must read article.

  21. Java Burn July 28, 2024 at 4:18 pm - Reply

    I like what you guys are up too. Such intelligent work and reporting! Carry on the superb works guys I’ve incorporated you guys to my blogroll. I think it’ll improve the value of my website :)

  22. ArnoldcEalt July 29, 2024 at 2:11 pm - Reply

    mexico pharmacies prescription drugs [url=https://mexicandeliverypharma.com/#]pharmacies in mexico that ship to usa[/url] buying prescription drugs in mexico online

  23. RichardBub July 29, 2024 at 3:48 pm - Reply

    http://mexicandeliverypharma.com/# mexican pharmaceuticals online

  24. Waynedow July 29, 2024 at 4:13 pm - Reply

    medicine in mexico pharmacies: п»їbest mexican online pharmacies – п»їbest mexican online pharmacies

  25. DominicCen July 29, 2024 at 4:13 pm - Reply

    buying prescription drugs in mexico: buying from online mexican pharmacy – pharmacies in mexico that ship to usa

  26. where to hire a hacker July 29, 2024 at 5:12 pm - Reply

    Hi, i read your blog from time to time and i own a similar one and i was just curious if you get a lot of spam remarks? If so how do you prevent it, any plugin or anything you can advise? I get so much lately it’s driving me mad so any help is very much appreciated.

  27. ArnoldcEalt July 29, 2024 at 9:08 pm - Reply

    buying prescription drugs in mexico [url=https://mexicandeliverypharma.online/#]mexican drugstore online[/url] buying prescription drugs in mexico

  28. Waynedow July 29, 2024 at 11:14 pm - Reply

    buying prescription drugs in mexico: mexican border pharmacies shipping to usa – mexican border pharmacies shipping to usa

  29. RichardBub July 30, 2024 at 12:20 am - Reply

    http://mexicandeliverypharma.com/# mexican border pharmacies shipping to usa

  30. ArnoldcEalt July 30, 2024 at 4:08 am - Reply

    mexican mail order pharmacies [url=https://mexicandeliverypharma.com/#]mexico drug stores pharmacies[/url] buying from online mexican pharmacy

  31. DominicCen July 30, 2024 at 6:01 am - Reply

    medication from mexico pharmacy: mexico drug stores pharmacies – п»їbest mexican online pharmacies

  32. Waynedow July 30, 2024 at 6:05 am - Reply

    buying prescription drugs in mexico online: mexican rx online – pharmacies in mexico that ship to usa

  33. RichardBub July 30, 2024 at 9:40 am - Reply

    https://mexicandeliverypharma.online/# pharmacies in mexico that ship to usa

  34. NelsonRax July 30, 2024 at 11:26 am - Reply

    mexican mail order pharmacies: mexico drug stores pharmacies – mexican rx online

  35. ArnoldcEalt July 30, 2024 at 11:47 am - Reply

    purple pharmacy mexico price list [url=http://mexicandeliverypharma.com/#]mexico drug stores pharmacies[/url] mexican pharmaceuticals online

  36. DominicCen July 30, 2024 at 1:55 pm - Reply

    best online pharmacies in mexico: mexico pharmacies prescription drugs – mexican online pharmacies prescription drugs

  37. Waynedow July 30, 2024 at 1:59 pm - Reply

    mexican rx online: п»їbest mexican online pharmacies – п»їbest mexican online pharmacies

  38. NelsonRax July 30, 2024 at 7:37 pm - Reply

    mexican drugstore online: mexican drugstore online – mexican rx online

  39. ArnoldcEalt July 30, 2024 at 7:53 pm - Reply

    mexico pharmacy [url=http://mexicandeliverypharma.com/#]mexican rx online[/url] medication from mexico pharmacy

  40. DominicCen July 30, 2024 at 10:04 pm - Reply

    purple pharmacy mexico price list: mexican online pharmacies prescription drugs – mexican border pharmacies shipping to usa

  41. Waynedow July 30, 2024 at 10:10 pm - Reply

    buying prescription drugs in mexico online: mexican rx online – best online pharmacies in mexico

  42. Cig July 31, 2024 at 2:20 am - Reply

    During his annual Victory Day speech in Moscow’s Red Square on Tuesday, Russian President Vladimir Putin claimed that the Ukraine war was “unleashed” on Russia and blamed “Western global elites” while calling Ukrainian President Volodymyr Zelenskyy a puppet. This page will automatically redirect in 5 seconds… As the war drags on, communities that were steadfast in their commitment to the effort have been shaken by the unending violence on the front line. Video Ukraine war Today’s breaking news and more in your inbox Russia’s president has signaled an increase in income and corporate taxes that will help finance the war. The move reflects his firm control over Russian policy. ‘).concat(o).concat(n,” However, it has proven very difficult to secure reliable figures for the Ukraine war, with Russia playing down the scale of its losses, and Kyiv avoiding reporting specific numbers.
    https://paxtonojbu134791.ambien-blog.com/32783460/social-earning-sites
    Tools & Features Tracking UTM’s are a great way to monitor the success of your Facebook & Instagram ads after iOS14 in 2022. Running your Facebook paid ads on a schedule may be the most efficient way to spend your budget since you can choose only to serve your ad when your target audience is most likely to be on Facebook. You can only set a schedule if you create a lifetime budget for your ad. Catch your audience’s attention with the content of your ad. It’s what they see when the ad is displayed and should clearly state what you’re promoting and encourage them to click it. It is dependent on the intention of your marketing campaign and the budget. If you want to warm up your lead and make them aware of the problem they face and have a limited budget, Facebook ads can be ideal. On the contrary, Google ads are focused on people already looking for the product or solution you are providing. They are hot leads who need instant answers and will cost you more than Facebook ads.

  43. NelsonRax July 31, 2024 at 3:56 am - Reply

    mexico drug stores pharmacies: mexican border pharmacies shipping to usa – п»їbest mexican online pharmacies

  44. ArnoldcEalt July 31, 2024 at 4:05 am - Reply

    purple pharmacy mexico price list [url=http://mexicandeliverypharma.com/#]mexico drug stores pharmacies[/url] buying from online mexican pharmacy

  45. DominicCen July 31, 2024 at 6:08 am - Reply

    buying prescription drugs in mexico online: mexican rx online – buying prescription drugs in mexico

  46. ArnoldcEalt July 31, 2024 at 12:13 pm - Reply

    medication from mexico pharmacy [url=https://mexicandeliverypharma.com/#]purple pharmacy mexico price list[/url] mexican pharmaceuticals online

  47. DominicCen July 31, 2024 at 2:11 pm - Reply

    buying prescription drugs in mexico online: purple pharmacy mexico price list – buying from online mexican pharmacy

  48. Waynedow July 31, 2024 at 2:27 pm - Reply

    reputable mexican pharmacies online: mexican rx online – mexican drugstore online

  49. MatthewJef August 5, 2024 at 12:30 pm - Reply

    cheap propecia without insurance: order cheap propecia without prescription – propecia rx

  50. KevinGon August 5, 2024 at 1:50 pm - Reply

    nolvadex during cycle: nolvadex for sale amazon – tamoxifen hip pain

Leave A Comment

view related content