Greased Lightning
data:image/s3,"s3://crabby-images/741ee/741ee4d3193bc0679d14f4e9a95b07141af39fc3" alt=""
Sam Beckham
@samdbeckham
How to make your web site load really, really fast, as a progressive web app.
data:image/s3,"s3://crabby-images/a58b4/a58b4d8d2e475310af9484157c9a86108da2890c" alt=""
data:image/s3,"s3://crabby-images/b005d/b005df7037715a974400023e8a0c154e4f7226f7" alt=""
data:image/s3,"s3://crabby-images/de953/de9536f107e32c5110a0002f18a001f650cca469" alt=""
data:image/s3,"s3://crabby-images/756b3/756b316209c9f0aa266a368515b7bf044a6a5679" alt=""
BUY TICKETS TO FRONTEND NE
data:image/s3,"s3://crabby-images/de953/de9536f107e32c5110a0002f18a001f650cca469" alt=""
data:image/s3,"s3://crabby-images/de953/de9536f107e32c5110a0002f18a001f650cca469" alt=""
3G
WiFi
1s
3s
data:image/s3,"s3://crabby-images/de953/de9536f107e32c5110a0002f18a001f650cca469" alt=""
data:image/s3,"s3://crabby-images/de953/de9536f107e32c5110a0002f18a001f650cca469" alt=""
3G
WiFi
0.3s
0.3s
data:image/s3,"s3://crabby-images/de953/de9536f107e32c5110a0002f18a001f650cca469" alt=""
Offline
data:image/s3,"s3://crabby-images/26d52/26d52850997f4eacb337d1724d9fbbedf1ef0633" alt=""
data:image/s3,"s3://crabby-images/de953/de9536f107e32c5110a0002f18a001f650cca469" alt=""
3G
WiFi
0.3s
0.3s
0.3s
data:image/s3,"s3://crabby-images/de953/de9536f107e32c5110a0002f18a001f650cca469" alt=""
It's a
website
that acts like a
native app
Install to your home screen
Load offline
Receive push notifications
data:image/s3,"s3://crabby-images/0ad2a/0ad2aa10c20b412f668693d32d6032167a91a3ce" alt=""
data:image/s3,"s3://crabby-images/4776b/4776b532ab016a31c4330f0d72ab9a1179911a14" alt=""
No
'fancy pants'
framework
No
compilation
process
Just a
website
<disclaimer>
data:image/s3,"s3://crabby-images/da2b0/da2b038666ea3f67a90e94803d8cce8e4fbbf5e4" alt=""
It's a
progressive enhancement
It's still a fully functioning website
</disclaimer>
Lighthouse
"Wait, you said no frameworks"
– You, just now
It's just a list
Service worker
Lighthouse
200 when offline
non-javascript content
https
http => https
Fast enough on 3g
Prompted to install the web app
Custom Splash Screen
Themed Address bar
<meta viewport> tag
Sized correctly for the viewport
❌ Service worker
Lighthouse
❌ 200 when offline
✅ non-javascript content
✅ https
✅ http => https
✅ Fast enough on 3g
❌ Prompted to install the web app
❌ Custom Splash Screen
❌ Themed Address bar
✅ <meta viewport> tag
✅ Sized correctly for the viewport
✅
Non-Javascript content
Does it show some content when Javascript is turned off?
✅
Fast enough on 3G
Is it interactive in the first 10s on 3G speeds?
✅
<meta viewport>
tag
<meta
name="viewport"
content="
width=device-width,
initial-scale=1
"
>
<meta name="viewport" content="width=device-width,initial-scale=1">
✅
Sized correctly for the viewport
data:image/s3,"s3://crabby-images/de953/de9536f107e32c5110a0002f18a001f650cca469" alt=""
data:image/s3,"s3://crabby-images/e047f/e047ffefff0e96428552009bf8e758c30a1ad1d4" alt=""
❌
✅
✅
https
✅
https
http => https
data:image/s3,"s3://crabby-images/804b4/804b469ca8cb9edbe7175ef373633b60d8992118" alt=""
❌ Service worker
Lighthouse
❌ 200 when offline
❌ Prompted to install the web app
❌ Custom Splash Screen
❌ Themed Address bar
✅ https
✅ http => https
✅ non-javascript content
✅ Fast enough on 3g
✅ <meta viewport> tag
✅ Sized correctly for the viewport
❌
Service worker
💻
🌐
Browser
Server
request
response
💻
🌐
Browser
Server
🐲
Service
Worker
💻
🌐
Browser
Server
🐲
Service
Worker
cat-pic.png
cat-pic.png
data:image/s3,"s3://crabby-images/f25ba/f25ba6a926088ee1023d901c53889224353037c5" alt=""
data:image/s3,"s3://crabby-images/f25ba/f25ba6a926088ee1023d901c53889224353037c5" alt=""
💻
🌐
Browser
Server
🐲
Service
Worker
cat-pic.png
data:image/s3,"s3://crabby-images/f25ba/f25ba6a926088ee1023d901c53889224353037c5" alt=""
if (navigator.serviceWorker) {
navigator.serviceWorker.register(
'/serviceWorker.js', {
scope: '/'
}
);
}
Register
./scripts/main.js
self.addEventListener('install', event => {
// What do we want to do on install?
});
Install
./serviceWorker.js
self.addEventListener('install', event => {
event.waitUntil(
caches.open('name-of-the-cache')
.then(cache => cache.addAll([
'/assets/scripts/main.js',
'/assets/scripts/forms.js',
'/assets/css/main.css',
'/index.html'
]))
);
});
./serviceWorker.js
Install
self.addEventListener('fetch', event => {
// This is where the magic and
// the dragons live.
});
./serviceWorker.js
Fetch
self.addEventListener('fetch', event => {
const request = event.request;
event.respondWith(
caches.match(request)
.then(response => {
return response || fetch(request)
})
);
});
./serviceWorker.js
self.addEventListener('install', event => {
event.waitUntil(
caches.open('name-of-the-cache')
.then(cache => cache.addAll([
'/assets/scripts/main.js',
'/assets/scripts/forms.js',
'/assets/css/main.css',
'/index.html'
]))
);
});
self.addEventListener('fetch', event => {
const request = event.request;
event.respondWith(
caches.match(request)
.then(response => response || fetch(request))
);
});
./serviceWorker.js
✅
Service worker
✅
200 when offline
Lighthouse
❌ Prompted to install the web app
❌ Custom Splash Screen
❌ Themed Address bar
✅ Service worker
✅ 200 when offline
✅ https
✅ http => https
✅ non-javascript content
✅ Fast enough on 3g
✅ <meta viewport> tag
✅ Sized correctly for the viewport
❌
Custom Splash Screen
data:image/s3,"s3://crabby-images/fd15f/fd15f6098a7a0b9aa3fbcb43182819a8bcfc8de5" alt=""
data:image/s3,"s3://crabby-images/e047f/e047ffefff0e96428552009bf8e758c30a1ad1d4" alt=""
❌
Themed Address bar
data:image/s3,"s3://crabby-images/23939/2393907e9741832c3934259169b538315ed1c710" alt=""
data:image/s3,"s3://crabby-images/68283/6828300b803e3749640cbbce5eded0af6b42e7a3" alt=""
data:image/s3,"s3://crabby-images/12dcc/12dcc56d800ecbb3428def742b3f1d8753333183" alt=""
data:image/s3,"s3://crabby-images/0c101/0c101ced322944bca004bb38af91b590d0fb741c" alt=""
{
"name": "Frontend NE: The Conference",
"short_name": "Frontend NE",
"start_url": "/",
"scope": "/",
"display": "standalone",
"theme_color": "#4A4A4A",
"background_color": "#4A4A4A",
"icons": [{
"src": "/icon.png",
"sizes": "512x512",
"type": "image/png"
}]
}
./manifest.json
<head>
<!-- other head stuff -->
<link rel="manifest" href="/manifest.json">
</head>
./yourpage.html
✅
Custom Splash Screen
✅
Themed Address bar
Lighthouse
❌ Prompted to install the web app
✅ Service worker
✅ 200 when offline
✅ https
✅ http => https
✅ Custom Splash Screen
✅ Themed Address bar
✅ non-javascript content
✅ Fast enough on 3g
✅ <meta viewport> tag
✅ Sized correctly for the viewport
❌
Prompted to install the web app
Do literally nothing else
✅
Prompted to install the web app
✅ Service worker
Lighthouse
✅ 200 when offline
✅ https
✅ http => https
✅ Prompted to install the web app
✅ Custom Splash Screen
✅ Themed Address bar
✅ non-javascript content
✅ Fast enough on 3g
✅ <meta viewport> tag
✅ Sized correctly for the viewport
Thanks!
data:image/s3,"s3://crabby-images/741ee/741ee4d3193bc0679d14f4e9a95b07141af39fc3" alt=""
Sam Beckham
@samdbeckham
Slides: https://goo.gl/SPFP1V
BUY TICKETS TO FRONTEND NE
Greased Lightning
By Sam Beckham
Greased Lightning
- 2,786