Hacking to be performant

Apoorv Saxena
Apoorv SaxenaSpeaker, Workshop Organiser, Performance Coach at Wingify
Hacking to be Performant?
Talk: Performance Engineering
Speaker: Apoorv Saxena
Hacking to be performant
Time to run a poll
How many you consider
#perfmatters?
What performance
monitoring tools are you
using?
(To evaluate your Front End’s Performance)
How many of you have it as
part of your
“Continuous Deployment”?
Enough, let’s start Hacking
What do you mean by
“Hacking”?
What do you mean by
“Performant”?
Evolution of the Web: Browser & Technologies
Evolution
Is necessary, though it proceeds gradually and
takes some time, it accounts for everyone to be
on the same page.
Though, not everyone can afford to walk at the
same speed, they must run, jump obstacles, cut
corners and give their best shot.
Loading Webpages under
1 second
First pixel render time less
than 500ms
Running Applications at
60fps
Delivering a Jank Free Experience
#perfmatters
What are we Trying to fit?
● HTML5 Games
● Single Page Applications
● Animations
● Editors, Document Collaboration Tools
● WebRTC (Video, Audio)
and many more.
That’s it?
Not at all.
Everything available on Mobile must be
available via APIs on Web.
Let me tell you a story
From JS to Screen:
Style/Layout PaintingJS Compositing
keep < 16ms!
1. Add CSS rules in style via JS.
2. Recalculate style, maybe relayout.
3. Paint the browser’s mental model to a layer
4. Composite all layers into a final image
What causes Jank?
Style/Layout PaintingJS
16ms!
Draw
Commands CPU GPU
SCREEN
Extensive Upload
Rasterization in
Action
Performance Hacks:
Creating a separate layer for
elements requesting
frequent updates
Hacking to be performant
Hardware Acceleration
rules me
What about using Canvas
instead of DOM?
You must consider:
● Accessibility, Flipboard injects mirror of the content into an
invisible dom so it’s still in synch for VoiceOver.
● Canvas is not hardware accelerated on every browser
(accompanies device constraints).
DOM Rendering might become amazingly fast soon.
(Hint: remember project Ganesh).
Considered using DOMSprites?
Hacking to be performant
SCREEN
Project Ganesh:
Draw
Commands GPU
60fps is not required at every instance
Hacking to be performant
Note:
Our eyes are much more attuned to variance
than framerate.
A steady 30Hz looks better than 60Hz that
misses a few frames a second.
Thank You!
See jankfree.org, html5rocks.com for lots of info
1 of 35

Recommended

Automate devmachinesetup by
Automate devmachinesetupAutomate devmachinesetup
Automate devmachinesetupAshish K Agarwal
247 views5 slides
Task runners + theming automating your workflow by
Task runners + theming  automating your workflowTask runners + theming  automating your workflow
Task runners + theming automating your workflowJoshua Gilmer
101 views11 slides
Testing the way it should be by
Testing the way it should beTesting the way it should be
Testing the way it should beBrian Mann
550 views56 slides
Microsoft Breeze CA AI Workshop by
Microsoft Breeze CA AI WorkshopMicrosoft Breeze CA AI Workshop
Microsoft Breeze CA AI WorkshopAaron (Ari) Bornstein
196 views22 slides
Jakarta WordPress Meetup #9: Introducing VVV 2 by
Jakarta WordPress Meetup #9: Introducing VVV 2Jakarta WordPress Meetup #9: Introducing VVV 2
Jakarta WordPress Meetup #9: Introducing VVV 2WordPress
682 views16 slides
MVVM Light for UWP by
MVVM Light for UWPMVVM Light for UWP
MVVM Light for UWPRobert Iagar
604 views8 slides

More Related Content

What's hot

08 Workflow e strumenti web by
08 Workflow e strumenti web08 Workflow e strumenti web
08 Workflow e strumenti webFederico Russo
489 views16 slides
Makes JavaScript Fun Again by
Makes JavaScript Fun AgainMakes JavaScript Fun Again
Makes JavaScript Fun AgainAsep Bagja
754 views13 slides
Yeoman by
YeomanYeoman
YeomanMohammed Arif
3.2K views26 slides
Question 6 by
Question 6Question 6
Question 6Deeqaali95
122 views4 slides
Postmortem of a uwp xaml application development by
Postmortem of a uwp xaml application developmentPostmortem of a uwp xaml application development
Postmortem of a uwp xaml application developmentDavid Catuhe
771 views41 slides
React native by
React nativeReact native
React native🍉 Renan Araujo
101 views26 slides

What's hot(20)

Makes JavaScript Fun Again by Asep Bagja
Makes JavaScript Fun AgainMakes JavaScript Fun Again
Makes JavaScript Fun Again
Asep Bagja754 views
Postmortem of a uwp xaml application development by David Catuhe
Postmortem of a uwp xaml application developmentPostmortem of a uwp xaml application development
Postmortem of a uwp xaml application development
David Catuhe771 views
Visual Regression Testing with Wraith by Sauli Rajala
Visual Regression Testing with WraithVisual Regression Testing with Wraith
Visual Regression Testing with Wraith
Sauli Rajala1K views
wp cli- don’t fear the command line by Dwayne McDaniel
wp cli- don’t fear the command linewp cli- don’t fear the command line
wp cli- don’t fear the command line
Dwayne McDaniel1.7K views
WordPress security & sanitation for beginners by D'nelle Dowis
WordPress security & sanitation for beginnersWordPress security & sanitation for beginners
WordPress security & sanitation for beginners
D'nelle Dowis509 views
Kristof van roy-behind_the_scenes by nascomgenk
Kristof van roy-behind_the_scenesKristof van roy-behind_the_scenes
Kristof van roy-behind_the_scenes
nascomgenk461 views
Achieving Scale with HoloLens and BIM: Designing for interactions with large ... by Windows Developer
Achieving Scale with HoloLens and BIM: Designing for interactions with large ...Achieving Scale with HoloLens and BIM: Designing for interactions with large ...
Achieving Scale with HoloLens and BIM: Designing for interactions with large ...
Windows Developer652 views
Front end workflow with yeoman by hassan hafez
Front end workflow with yeomanFront end workflow with yeoman
Front end workflow with yeoman
hassan hafez922 views
Unit testing for User Interfaces by webmull
Unit testing for User InterfacesUnit testing for User Interfaces
Unit testing for User Interfaces
webmull447 views
The state of testing @ Microsoft by Robert MacLean
The state of testing @ MicrosoftThe state of testing @ Microsoft
The state of testing @ Microsoft
Robert MacLean12.1K views
Moving from MAMP to Vagrant by Jeremy Pry
Moving from MAMP to VagrantMoving from MAMP to Vagrant
Moving from MAMP to Vagrant
Jeremy Pry671 views

Similar to Hacking to be performant

Running HTML5 Mobile Web Games at 60fps by
Running HTML5 Mobile Web Games at 60fpsRunning HTML5 Mobile Web Games at 60fps
Running HTML5 Mobile Web Games at 60fpsApoorv Saxena
4.1K views66 slides
Presentation on Fresco by
Presentation on FrescoPresentation on Fresco
Presentation on FrescoTyrone Nicholas
516 views18 slides
Chrome Dev Summit Summary 2013 part 1 - what’s hot ? by
Chrome Dev Summit Summary 2013 part 1 - what’s hot ?Chrome Dev Summit Summary 2013 part 1 - what’s hot ?
Chrome Dev Summit Summary 2013 part 1 - what’s hot ?Sacha Leprêtre
2K views25 slides
Js foo famo.us- build native quality apps using html5 within a day by
Js foo  famo.us- build native quality apps using html5 within a dayJs foo  famo.us- build native quality apps using html5 within a day
Js foo famo.us- build native quality apps using html5 within a dayDebnath Sinha
227 views21 slides
Famo.us - build native quality apps using html5 within a day by
Famo.us - build native quality apps using html5 within a dayFamo.us - build native quality apps using html5 within a day
Famo.us - build native quality apps using html5 within a dayDebnath Sinha
948 views21 slides
Advanced #4 GPU & Animations by
Advanced #4   GPU & AnimationsAdvanced #4   GPU & Animations
Advanced #4 GPU & AnimationsVitali Pekelis
316 views212 slides

Similar to Hacking to be performant(20)

Running HTML5 Mobile Web Games at 60fps by Apoorv Saxena
Running HTML5 Mobile Web Games at 60fpsRunning HTML5 Mobile Web Games at 60fps
Running HTML5 Mobile Web Games at 60fps
Apoorv Saxena4.1K views
Chrome Dev Summit Summary 2013 part 1 - what’s hot ? by Sacha Leprêtre
Chrome Dev Summit Summary 2013 part 1 - what’s hot ?Chrome Dev Summit Summary 2013 part 1 - what’s hot ?
Chrome Dev Summit Summary 2013 part 1 - what’s hot ?
Sacha Leprêtre2K views
Js foo famo.us- build native quality apps using html5 within a day by Debnath Sinha
Js foo  famo.us- build native quality apps using html5 within a dayJs foo  famo.us- build native quality apps using html5 within a day
Js foo famo.us- build native quality apps using html5 within a day
Debnath Sinha227 views
Famo.us - build native quality apps using html5 within a day by Debnath Sinha
Famo.us - build native quality apps using html5 within a dayFamo.us - build native quality apps using html5 within a day
Famo.us - build native quality apps using html5 within a day
Debnath Sinha948 views
Advanced #4 GPU & Animations by Vitali Pekelis
Advanced #4   GPU & AnimationsAdvanced #4   GPU & Animations
Advanced #4 GPU & Animations
Vitali Pekelis316 views
Netflix Webkit-Based UI for TV Devices by Matt McCarthy
Netflix Webkit-Based UI for TV DevicesNetflix Webkit-Based UI for TV Devices
Netflix Webkit-Based UI for TV Devices
Matt McCarthy19.7K views
Html5 Game Development with Canvas by Pham Huy Tung
Html5 Game Development with CanvasHtml5 Game Development with Canvas
Html5 Game Development with Canvas
Pham Huy Tung930 views
Building a game engine with jQuery by Paul Bakaus
Building a game engine with jQueryBuilding a game engine with jQuery
Building a game engine with jQuery
Paul Bakaus14.8K views
Js foo famo.us- build native quality apps using html5 within a day by Debnath Sinha
Js foo  famo.us- build native quality apps using html5 within a dayJs foo  famo.us- build native quality apps using html5 within a day
Js foo famo.us- build native quality apps using html5 within a day
Debnath Sinha460 views
Simplicity - develop modern web apps with tiny frameworks and tools by Rui Carvalho
Simplicity - develop modern web apps with tiny frameworks and toolsSimplicity - develop modern web apps with tiny frameworks and tools
Simplicity - develop modern web apps with tiny frameworks and tools
Rui Carvalho4.6K views
How to Develop Progressive Web Apps in Flutter – Step by Step Guide.pptx by BOSC Tech Labs
How to Develop Progressive Web Apps in Flutter – Step by Step Guide.pptxHow to Develop Progressive Web Apps in Flutter – Step by Step Guide.pptx
How to Develop Progressive Web Apps in Flutter – Step by Step Guide.pptx
BOSC Tech Labs13 views
Java script anywhere. What Nombas was doing pre-acquisition. by Brent Noorda
Java script anywhere. What Nombas was doing pre-acquisition.Java script anywhere. What Nombas was doing pre-acquisition.
Java script anywhere. What Nombas was doing pre-acquisition.
Brent Noorda1.7K views
Responsive design and retina displays by Eli McMakin
Responsive design and retina displaysResponsive design and retina displays
Responsive design and retina displays
Eli McMakin8.7K views
JS Fest 2019. Денис Радин. AAA 3D графика в Web с ReactJS, BabylonJS и Unity3D by JSFestUA
JS Fest 2019. Денис Радин. AAA 3D графика в Web с ReactJS, BabylonJS и Unity3DJS Fest 2019. Денис Радин. AAA 3D графика в Web с ReactJS, BabylonJS и Unity3D
JS Fest 2019. Денис Радин. AAA 3D графика в Web с ReactJS, BabylonJS и Unity3D
JSFestUA387 views
AAA 3D GRAPHICS ON THE WEB WITH REACTJS + BABYLONJS + UNITY3D by Denis Radin ... by DevClub_lv
AAA 3D GRAPHICS ON THE WEB WITH REACTJS + BABYLONJS + UNITY3D by Denis Radin ...AAA 3D GRAPHICS ON THE WEB WITH REACTJS + BABYLONJS + UNITY3D by Denis Radin ...
AAA 3D GRAPHICS ON THE WEB WITH REACTJS + BABYLONJS + UNITY3D by Denis Radin ...
DevClub_lv791 views
WordPress automation and CI by Ran Bar-Zik
WordPress automation and CIWordPress automation and CI
WordPress automation and CI
Ran Bar-Zik2K views
Tech Thursdays: Building Products by Hayden Bleasel
Tech Thursdays: Building ProductsTech Thursdays: Building Products
Tech Thursdays: Building Products
Hayden Bleasel733 views

Recently uploaded

fakenews_DBDA_Mar23.pptx by
fakenews_DBDA_Mar23.pptxfakenews_DBDA_Mar23.pptx
fakenews_DBDA_Mar23.pptxdeepmitra8
16 views34 slides
Design_Discover_Develop_Campaign.pptx by
Design_Discover_Develop_Campaign.pptxDesign_Discover_Develop_Campaign.pptx
Design_Discover_Develop_Campaign.pptxShivanshSeth6
37 views20 slides
BCIC - Manufacturing Conclave - Technology-Driven Manufacturing for Growth by
BCIC - Manufacturing Conclave -  Technology-Driven Manufacturing for GrowthBCIC - Manufacturing Conclave -  Technology-Driven Manufacturing for Growth
BCIC - Manufacturing Conclave - Technology-Driven Manufacturing for GrowthInnomantra
6 views4 slides
ASSIGNMENTS ON FUZZY LOGIC IN TRAFFIC FLOW.pdf by
ASSIGNMENTS ON FUZZY LOGIC IN TRAFFIC FLOW.pdfASSIGNMENTS ON FUZZY LOGIC IN TRAFFIC FLOW.pdf
ASSIGNMENTS ON FUZZY LOGIC IN TRAFFIC FLOW.pdfAlhamduKure
6 views11 slides
MongoDB.pdf by
MongoDB.pdfMongoDB.pdf
MongoDB.pdfArthyR3
45 views6 slides
_MAKRIADI-FOTEINI_diploma thesis.pptx by
_MAKRIADI-FOTEINI_diploma thesis.pptx_MAKRIADI-FOTEINI_diploma thesis.pptx
_MAKRIADI-FOTEINI_diploma thesis.pptxfotinimakriadi
8 views32 slides

Recently uploaded(20)

fakenews_DBDA_Mar23.pptx by deepmitra8
fakenews_DBDA_Mar23.pptxfakenews_DBDA_Mar23.pptx
fakenews_DBDA_Mar23.pptx
deepmitra816 views
Design_Discover_Develop_Campaign.pptx by ShivanshSeth6
Design_Discover_Develop_Campaign.pptxDesign_Discover_Develop_Campaign.pptx
Design_Discover_Develop_Campaign.pptx
ShivanshSeth637 views
BCIC - Manufacturing Conclave - Technology-Driven Manufacturing for Growth by Innomantra
BCIC - Manufacturing Conclave -  Technology-Driven Manufacturing for GrowthBCIC - Manufacturing Conclave -  Technology-Driven Manufacturing for Growth
BCIC - Manufacturing Conclave - Technology-Driven Manufacturing for Growth
Innomantra 6 views
ASSIGNMENTS ON FUZZY LOGIC IN TRAFFIC FLOW.pdf by AlhamduKure
ASSIGNMENTS ON FUZZY LOGIC IN TRAFFIC FLOW.pdfASSIGNMENTS ON FUZZY LOGIC IN TRAFFIC FLOW.pdf
ASSIGNMENTS ON FUZZY LOGIC IN TRAFFIC FLOW.pdf
AlhamduKure6 views
MongoDB.pdf by ArthyR3
MongoDB.pdfMongoDB.pdf
MongoDB.pdf
ArthyR345 views
_MAKRIADI-FOTEINI_diploma thesis.pptx by fotinimakriadi
_MAKRIADI-FOTEINI_diploma thesis.pptx_MAKRIADI-FOTEINI_diploma thesis.pptx
_MAKRIADI-FOTEINI_diploma thesis.pptx
fotinimakriadi8 views
Ansari: Practical experiences with an LLM-based Islamic Assistant by M Waleed Kadous
Ansari: Practical experiences with an LLM-based Islamic AssistantAnsari: Practical experiences with an LLM-based Islamic Assistant
Ansari: Practical experiences with an LLM-based Islamic Assistant
M Waleed Kadous5 views
GDSC Mikroskil Members Onboarding 2023.pdf by gdscmikroskil
GDSC Mikroskil Members Onboarding 2023.pdfGDSC Mikroskil Members Onboarding 2023.pdf
GDSC Mikroskil Members Onboarding 2023.pdf
gdscmikroskil58 views
REACTJS.pdf by ArthyR3
REACTJS.pdfREACTJS.pdf
REACTJS.pdf
ArthyR334 views
Searching in Data Structure by raghavbirla63
Searching in Data StructureSearching in Data Structure
Searching in Data Structure
raghavbirla6314 views
SUMIT SQL PROJECT SUPERSTORE 1.pptx by Sumit Jadhav
SUMIT SQL PROJECT SUPERSTORE 1.pptxSUMIT SQL PROJECT SUPERSTORE 1.pptx
SUMIT SQL PROJECT SUPERSTORE 1.pptx
Sumit Jadhav 18 views
2023Dec ASU Wang NETR Group Research Focus and Facility Overview.pptx by lwang78
2023Dec ASU Wang NETR Group Research Focus and Facility Overview.pptx2023Dec ASU Wang NETR Group Research Focus and Facility Overview.pptx
2023Dec ASU Wang NETR Group Research Focus and Facility Overview.pptx
lwang78109 views
Design of machine elements-UNIT 3.pptx by gopinathcreddy
Design of machine elements-UNIT 3.pptxDesign of machine elements-UNIT 3.pptx
Design of machine elements-UNIT 3.pptx
gopinathcreddy33 views

Hacking to be performant