Superpowers of browser's Web API
Web API
console.log(1);
setTimeout(() => console.log(2), 0);
console.log(3);
data:image/s3,"s3://crabby-images/fb69b/fb69bc62b4259c14e9c8cad780ec5a12455b4719" alt=""
Web API
?
Collection of built-in interfaces that allow developers to interact with and manipulate web pages and web applications within a web browser.
Web API
data:image/s3,"s3://crabby-images/7aa1e/7aa1ee8b5aa1eaf7e8fc722d2c97c11ab6ff6b72" alt=""
- Web API docs
Nikola Mitrović
Development Lead & Software Engineer
Vega IT
Novi Sad, Serbia
data:image/s3,"s3://crabby-images/63f92/63f9254a174e6e87f2dff0a36981e610e321a1da" alt=""
data:image/s3,"s3://crabby-images/4f44b/4f44bbd183cdd047406cfe128e93d42f8434e864" alt=""
Intersection Observer API
-
Provides a way to asynchronously observe changes in the intersection of a target element with an ancestor element or with a top-level document's viewport
Intersection Observer API
import { useState, useEffect, RefObject } from 'react';
export const useVisible = (
ref: RefObject<HTMLDivElement>,
options = {
root: null,
rootMargin: '0px',
threshold: 1.0
}
) => {
const [isVisible, setIsVisible] = useState<boolean>(false);
useEffect(() => {
const { current: elementRef } = ref;
if (elementRef) {
const observer = new IntersectionObserver(
([entry]) => setIsVisible(entry.isIntersecting), options
);
observer.observe(elementRef);
return () => observer.unobserve(elementRef);
}
}, [ref, options]);
return isVisible;
};
data:image/s3,"s3://crabby-images/2ac07/2ac073b92fdaa8f3f2a1d37f35d72b87908be20c" alt=""
data:image/s3,"s3://crabby-images/3a8e8/3a8e880e4cd671d61f9ea63ee634e6b6e75d3884" alt=""
data:image/s3,"s3://crabby-images/49323/49323e3aea671d69f407277d9369974e456be1f4" alt=""
data:image/s3,"s3://crabby-images/07ecc/07ecc43d37df24e02da2337f2c61293f2ab92bde" alt=""
data:image/s3,"s3://crabby-images/2e1a8/2e1a877363ff1b437067867809022ebf65384ac4" alt=""
data:image/s3,"s3://crabby-images/0a39d/0a39d62a96a4d7ab672df11f10ed70bb69a8e1cb" alt=""
Intersection Observer API - Use Cases
Lazy-load images
Infinite scroll lists
Defer animations
Save compute power
03
02
04
01
Intersection Observer API - Browser Support
data:image/s3,"s3://crabby-images/ebccd/ebccd3db6964f64f9f3931439cb58b3df69c82c0" alt=""
data:image/s3,"s3://crabby-images/75a19/75a19a46301f9655dfba98341b66e57f64f26566" alt=""
data:image/s3,"s3://crabby-images/1f48c/1f48c77eb5ef66184ddcd4356185181e1299940e" alt=""
Page Visibility API
-
Provides events you can watch for to know the current visibility state of the page
-
Triggers when user
switches tab
minimizes window
puts another window as overlay
locks/turns off device
Page Visibility API
import { useEffect, useState } from "react";
export const usePageVisibility = () => {
const [pageVisible, setPageVisible] = useState<boolean>(true);
useEffect(() => {
const handleVisibilityChange = () => {
const isPageVisible = document.visibilityState === "visible";
setPageVisible(isPageVisible);
};
document.addEventListener("visibilitychange", handleVisibilityChange);
return () => {
document.removeEventListener("visibilitychange", handleVisibilityChange);
};
}, []);
return pageVisible;
};
data:image/s3,"s3://crabby-images/db526/db5267ee8b72d78d1f3ab81e7563448d33c1a0a1" alt=""
data:image/s3,"s3://crabby-images/af4c0/af4c0881170eb6ea9aaaa0975e6a4af879af86fd" alt=""
data:image/s3,"s3://crabby-images/6f9f1/6f9f12ebf4c3451651ec7500867c1ca7ccd205fb" alt=""
Page Visibility API - Use Cases
Improving performance
01
Pause audio/video
02
Detect page visit count
03
Poll server data
04
Carousel
05
Page Visibility API - Browser Support
data:image/s3,"s3://crabby-images/ebccd/ebccd3db6964f64f9f3931439cb58b3df69c82c0" alt=""
data:image/s3,"s3://crabby-images/75a19/75a19a46301f9655dfba98341b66e57f64f26566" alt=""
data:image/s3,"s3://crabby-images/1f48c/1f48c77eb5ef66184ddcd4356185181e1299940e" alt=""
Screen Wake Lock API
-
Prevent devices from locking the screen when an application needs to keep running
- Only visible (active) documents can acquire the screen wake lock
Screen Wake Lock API
import { useEffect, useCallback, useRef } from 'react';
export const useWakeLock = (shouldWakeLock = false) => {
let sentinel = useRef<WakeLockSentinel | null>(null);
const requestWakeLockSentinel = useCallback(async () => {
sentinel.current = await navigator.wakeLock.request('screen');
}, []);
const releaseWakeLockSentinel = useCallback(async () => {
await sentinel.current?.release();
sentinel.current = null;
}, []);
useEffect(() => {
(async () => {
if (shouldWakeLock) {
await requestWakeLockSentinel();
return releaseWakeLockSentinel;
}
await releaseWakeLockSentinel();
})();
}, [shouldWakeLock, requestWakeLockSentinel, releaseWakeLockSentinel]);
return { isWakeLock: !!sentinel.current };
};
data:image/s3,"s3://crabby-images/7b501/7b501254e5ec26ea8afc2b4d204374f1aeb06de1" alt=""
data:image/s3,"s3://crabby-images/4cb98/4cb980e7b9a7b281d29c6e581b6a897b0d4914c7" alt=""
data:image/s3,"s3://crabby-images/abe03/abe03c238586ed36fabb6db6939141c85412ca5a" alt=""
Screen Wake Lock API - Use Cases
Reading an ebook
Presenting to an audience
Following a recipe
Map navigation
Scanning a QR / barcode
03
05
02
04
01
Screen Wake Lock API - Browser Support
data:image/s3,"s3://crabby-images/ebccd/ebccd3db6964f64f9f3931439cb58b3df69c82c0" alt=""
data:image/s3,"s3://crabby-images/75a19/75a19a46301f9655dfba98341b66e57f64f26566" alt=""
data:image/s3,"s3://crabby-images/1f48c/1f48c77eb5ef66184ddcd4356185181e1299940e" alt=""
Screen Wake Lock API - Drawbacks
Web API - Bonus points
-
Network API
-
Beacon API
-
Media Session API
-
Background Sync API
-
Background Fetch API
-
Broadcast Channel API
Web API - Takeaways
-
Standardized code
-
Standardized code
-
Standardized code
-
Smooth learning curve
-
Increase performance of web apps
With great power comes great responsibility
Green JavaScript
data:image/s3,"s3://crabby-images/c6c64/c6c64b37bf6504fa6fd146ec2674cdd10c35de5c" alt=""
Internet is consuming 21% of the electricity
check out carbon footprint
website traffic
energy intensity
data transfers
data:image/s3,"s3://crabby-images/f10e5/f10e55d81406d82ed38594080ee6ac3c8634b889" alt=""
Thank you!
n.mitrovic@vegait.rs
You can find me at
Link to the slides
data:image/s3,"s3://crabby-images/a9946/a9946417e938a8e239618fa057c28bf61f38d5c6" alt=""
Superpowers of browser's Web API
By nmitrovic
Superpowers of browser's Web API
- 172