Done in 0.0166666666 seconds
I'm Alex, nice to meet you!
@alexnmoldovan
Co-Founder @JSHeroes
✍ freecodecamp.org/news/author/alexnm/
No Servus 🇷🇴Timișoara!
Open Source Engineer @teleportHQ
http://bit.ly/revojs-alex
"We will build sites that perform badly"
"We shouldn't be afraid of getting our hands dirty"
Browser Rendering Pipeline
JavaScript
Style Calc
Layout
Paint
Composite
1 second = 60 frames
1/60 = 0.0166666666s
= 16 ms for rendering
16 ms
16 ms
16 ms
16 ms
10ms
10ms
10ms
10ms
In an ideal world...
javascript logic
business logic
event handlers
data fetching
dom diffing
data processing
...
16 ms
16 ms
16 ms
16 ms
10ms
40ms
In the real world...
Audit Time!
1. DOM Access
Multiple DOM accesses
for (let index = 0; index < newsItems.length; index++) {
const newsBox = document.createElement('div')
/* ... */
const newsItemsList = document.getElementById('news-items-list')
newsItemsList.appendChild(newsBox)
}
Involuntarily Layout Trigger
const header = document.getElementById('header')
function handleScroll() {
if (window.scrollY > 50) {
header.style.position = "fixed"
}
}
Forced Synchronous Layout = FSL
FSL = Layout Trashing
const header = document.getElementById('header')
function handleScroll() {
if (window.scrollY > 50) {
header.style.position = "fixed"
}
}
1. DOM Access
2. JavaScript
Avoid Long Running Handlers
Event Throttling
Passive Event Listeners
addEventListener('touchstart', onTouchStart, {passive: true});
1. DOM Access
2. JavaScript
3. Animations
JavaScript Animations
function animateBox() {
/* ... */
offset = offset + step
box.style.marginLeft = offset + "px";
/* ... */
requestAnimationFrame(animateBox);
}
Style
Layout
Paint
Composite
Style
Layout
Paint
Composite
Style
Layout
Paint
Composite
CSS Animations
Layout
Paint
Composite
Paint
Composite
Composite
Does it change the geometry of the element?
(ex: width, margin, border)
Is it a visual property?
(ex: color, background-color, visibility)
Does it promote the element to a new layer?
(ex: transform, opacity)
will-change
Use it as a last resort
Don't over use it, composition is not cheap
Test how the browser optimizes the layers before using it
Recap
Avoid unnecessary or repetitive DOM access
Use requestAnimationFrame for all visual delays / animations
Throttle sensitive event handlers (ex: scroll, resize)
Use passive event listeners for an easy win
Avoid forced reflows / layout trashing
Prefer transform and opacity for css animations
Use will-change as a last resort to promote an element to its own layer
Resources
I'm open for questions!
@alexnmoldovan
Co-Founder @JSHeroes
✍ freecodecamp.org/news/author/alexnm/
Mulțam fain 🇷🇴Timișoara!
Open Source Engineer @teleportHQ
http://bit.ly/revojs-alex
Ciao ciao!
Done in 0.0166666666 seconds
By Alex Moldovan
Done in 0.0166666666 seconds
Presented at revo.js in Oct 2019
- 1,906