Progressive Web Apps
A Brief Introduction
Alexandru Grigoruta
zis si Grigi
sau Grongo
data:image/s3,"s3://crabby-images/ba8f1/ba8f14728f2cad9ba52ba8b7fe534307cc5dff82" alt=""
data:image/s3,"s3://crabby-images/242f0/242f0ad72bbc1aa27b62f6ac2b53ecca9ed95095" alt=""
data:image/s3,"s3://crabby-images/4b287/4b2873b93b04c35197611ba9211a82841267e5ae" alt=""
data:image/s3,"s3://crabby-images/7e36c/7e36c2f9d701254b5b95d171a1082473856f12b8" alt=""
data:image/s3,"s3://crabby-images/cdb1c/cdb1cd8600192fcbf100e43386af29b5322c9d46" alt=""
A Progressive Web App (PWA) is a web app that uses modern web capabilities to deliver an app-like experience to users
PW What Now?
Mobile First Design
data:image/s3,"s3://crabby-images/b30c2/b30c278d06cbb477067b908ab1585982aba96aed" alt=""
data:image/s3,"s3://crabby-images/33771/33771110b5b73752c4559ae72838d8b3ee7716f7" alt=""
data:image/s3,"s3://crabby-images/33771/33771110b5b73752c4559ae72838d8b3ee7716f7" alt=""
data:image/s3,"s3://crabby-images/33771/33771110b5b73752c4559ae72838d8b3ee7716f7" alt=""
data:image/s3,"s3://crabby-images/8e26d/8e26db6ef902e574a44684c224516976e111bc33" alt=""
data:image/s3,"s3://crabby-images/a3143/a3143fe023d6a4c407e6b0f8e0b7245fe76b2bd4" alt=""
data:image/s3,"s3://crabby-images/f5266/f5266c7057873c4303a7c6a71bf8db4d401b365a" alt=""
Native Apps
Progressive Web Apps
Hybrid Apps
data:image/s3,"s3://crabby-images/90860/90860f8f50ae40e3e82f16fa2b888383079a842b" alt=""
data:image/s3,"s3://crabby-images/3d6e8/3d6e827bfe3b92af60e4a1472e8cc18290a00a77" alt=""
data:image/s3,"s3://crabby-images/dd097/dd097024cd26b243267725baf4eef131afcc0c7b" alt=""
data:image/s3,"s3://crabby-images/11fb9/11fb92d6eb037467aad880812f1c59d12cbf128b" alt=""
data:image/s3,"s3://crabby-images/09218/09218d9588d3f6d961544f95227ae45be3874c89" alt=""
data:image/s3,"s3://crabby-images/1b087/1b087448235a22d577901a2f0517754d9d1ac127" alt=""
data:image/s3,"s3://crabby-images/98437/98437400366a3d6f8c57049cc0325d8c25032961" alt=""
Requirements. Requirements everywhere
-
Progressive - Work for every user, regardless of browser choice, because they are built with progressive enhancement as a core tenet.
-
Responsive - Fit any form factor, desktop, mobile, tablet, or whatever is next.
-
Connectivity independent - Enhanced with service workers to work offline or on low quality networks.
-
App-like - Use the app-shell model to provide app-style navigation and interactions.
-
Fresh - Always up-to-date thanks to the service worker update process.
-
Safe - Served via HTTPS to prevent snooping and ensure content has not been tampered with.
-
Discoverable - Are identifiable as “applications” thanks to W3C manifests and service worker registration scope allowing search engines to find them.
-
Re-engageable - Make re-engagement easy through features like push notifications.
-
Installable - Allow users to “keep” apps they find most useful on their home screen without the hassle of an app store.
-
Linkable - Easily share via URL and not require complex installation.
tl;dr
Requirements again. But visual this time
Progressive
data:image/s3,"s3://crabby-images/108c6/108c6a4957055a37915d726b2306d3926f90e0ff" alt=""
data:image/s3,"s3://crabby-images/ed501/ed5012f6c6c361367ccc663a3c4e9edf68a6db59" alt=""
Responsive
data:image/s3,"s3://crabby-images/aa3c7/aa3c70bd4a1375d4073a5a859f5ed3f860e66407" alt=""
Connectivity Independent
data:image/s3,"s3://crabby-images/9f821/9f8213adbaa417ad64577daf98c6b7cfdf8720b3" alt=""
App-Like
data:image/s3,"s3://crabby-images/00b4f/00b4ff5bf7ca1b68cabc480603df671baacd528d" alt=""
Fresh
data:image/s3,"s3://crabby-images/25d2c/25d2c1564f3a067453f4fd75abe84a0b143a4858" alt=""
Safe
data:image/s3,"s3://crabby-images/ee01d/ee01d75a64e5d1cce7826860758aa3266f4274b5" alt=""
Discoverable
data:image/s3,"s3://crabby-images/398a4/398a4e31e4097251f47bbb4aa89e26ec7ad2e574" alt=""
Re-Engagable
data:image/s3,"s3://crabby-images/be1ba/be1baad47db55d139690e0f61f39bc27ccd80575" alt=""
Installable
data:image/s3,"s3://crabby-images/9e505/9e50574158373bfac31e0c975b7b7359e10341e7" alt=""
Linkable
Ugh. I don't have 4G here.
data:image/s3,"s3://crabby-images/fcde6/fcde6eb5a6cc65dd9119b7ac007815ad63653ec1" alt=""
data:image/s3,"s3://crabby-images/a93ed/a93ed14eae9faaac813085297a8f10eb56084677" alt=""
data:image/s3,"s3://crabby-images/adc49/adc49df8301dd988b1f67579b12b687270d95171" alt=""
Basic Service Worker
data:image/s3,"s3://crabby-images/80e16/80e16055fb0939106f58e4012e5c249bac6cd64d" alt=""
if ('serviceWorker' in navigator) {
window.addEventListener('load', function() {
navigator.serviceWorker.register('/sw.js').then(function(registration) {
// Registration was successful
console.log('ServiceWorker registration successful with scope: ', registration.scope);
}, function(err) {
// registration failed :(
console.log('ServiceWorker registration failed: ', err);
});
});
}
var CACHE_NAME = 'my-site-cache-v1';
var urlsToCache = [
'/',
'/styles/main.css',
'/script/main.js'
];
self.addEventListener('install', function(event) {
// Perform install steps
event.waitUntil(
caches.open(CACHE_NAME)
.then(function(cache) {
console.log('Opened cache');
return cache.addAll(urlsToCache);
})
);
});
self.addEventListener('fetch', function(event) {
event.respondWith(
caches.match(event.request)
.then(function(response) {
// Cache hit - return response
if (response) {
return response;
}
return fetch(event.request);
}
)
);
});
How do you even?
data:image/s3,"s3://crabby-images/b90be/b90be0a3c6fcd4de515cf7e5af2067ecd2e06728" alt=""
Tell me more about yourself
{
"name": "HackerWeb",
"short_name": "HackerWeb",
"start_url": ".",
"display": "standalone",
"background_color": "#fff",
"description": "A simply readable Hacker News app.",
"icons": [{
"src": "images/touch/homescreen48.png",
"sizes": "48x48",
"type": "image/png"
}, {
"src": "images/touch/homescreen72.png",
"sizes": "72x72",
"type": "image/png"
}, {
"src": "images/touch/homescreen96.png",
"sizes": "96x96",
"type": "image/png"
}, {
"src": "images/touch/homescreen144.png",
"sizes": "144x144",
"type": "image/png"
}, {
"src": "images/touch/homescreen168.png",
"sizes": "168x168",
"type": "image/png"
}, {
"src": "images/touch/homescreen192.png",
"sizes": "192x192",
"type": "image/png"
}],
"related_applications": [{
"platform": "play",
"url": "https://play.google.com/store/apps/details?id=cheeaun.hackerweb"
}]
}
<link rel="manifest" href="/manifest.webmanifest">
<!------------------- OR ------------------->
<link rel="manifest" href="/manifest.json">
Oh look! A notification!
data:image/s3,"s3://crabby-images/1851c/1851cd2e35a314851f3f709c966aef22f56a4e73" alt=""
Let's find some PWAs y'all!
Q & A
Thank you!
Useful links and resources
Intro in PWAs
By alexgrigi
Intro in PWAs
- 599