Chrome DevTools
Tools & Tricks
Jon Rojí Taboada
https://bit.ly/2WGbN9q
Jon Rojí Taboada
🦄 🖌️ 🍺
data:image/s3,"s3://crabby-images/a4e9b/a4e9bee207ae0b132d81c4f85df1307c1078bb60" alt=""
Frontend at Sngular - @Jnroji
https://bit.ly/2WGbN9q
Disclaimer!
DETECT, TOOLS AND TIPS, NOT FIX
Chrome DevTools
💻
😄
🤨
🤯
console.log()
console.log()
console.log()
console.log()
console.log()
console.log()
console.log()
console.log()
Chrome DevTools
💻
console.log() 🔍
DevTools 🔬 🔧
Chrome DevTools
✏️ DOM & styles
▶️ Console Master
📂 Sources
✋ Debuggers & Breakpoints
🌐 Network
📈 Coverage
🧙♀️ Tools & tricks
Chrome DevTools DOM and styles
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/45cb3/45cb35f4b5762134978b96a7d45bd1e205adb4fd" alt=""
data:image/s3,"s3://crabby-images/55d57/55d57c9a00cef16307ba51625e966f8b823a4fcf" alt=""
Client
Unknown behaviors
Chrome DevTools - DOM and styles
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/23d2e/23d2ec95e3b02f8d5a2db3d384624a8175555d6e" alt=""
data:image/s3,"s3://crabby-images/5f721/5f721f021747c91ad39b391826c4039224fd6da6" alt=""
DOM
CSS
Chrome DevTools - DOM and styles
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/23d2e/23d2ec95e3b02f8d5a2db3d384624a8175555d6e" alt=""
Can select and edit an HTML node and all properties
data:image/s3,"s3://crabby-images/961cb/961cb8c6edfc9fe54c447e2b06406d8bc07e2ed2" alt=""
data:image/s3,"s3://crabby-images/b7e48/b7e48fdcfd0e12676341a8d7be80e4895444c631" alt=""
And store the element as temp1 ... tempn on console to explore it
Chrome DevTools - DOM and styles
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/23d2e/23d2ec95e3b02f8d5a2db3d384624a8175555d6e" alt=""
Copy option got some great options
data:image/s3,"s3://crabby-images/bf75d/bf75df0f3fc1185e3d7dcedaabdb07ba316dfd47" alt=""
You can copy the css selector, in order to obtain the element. SO USEFUL for testing porpouses
data:image/s3,"s3://crabby-images/5d730/5d730b32349f7c3ec72839db30dae4d6485ea5a4" alt=""
Chrome DevTools - DOM and styles
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/5f721/5f721f021747c91ad39b391826c4039224fd6da6" alt=""
Styles
data:image/s3,"s3://crabby-images/f61cb/f61cb69886f98a0be151a22278f2ec6c8453d07f" alt=""
Element
states modifier
data:image/s3,"s3://crabby-images/1b01a/1b01a3ba6a052eff6484590a061420028afa04ee" alt=""
Element
classes modifier
Nice when toggling classes
data:image/s3,"s3://crabby-images/d733f/d733fa905cf4147d5c2f7190bbcc773f6be96a69" alt=""
data:image/s3,"s3://crabby-images/5d730/5d730b32349f7c3ec72839db30dae4d6485ea5a4" alt=""
Chrome DevTools - DOM and styles
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
Styles
data:image/s3,"s3://crabby-images/dc208/dc2080cfd0bc59bb154c196f12a97a4366c13d79" alt=""
Class addition
If we maintain pressed for a few seconds, we can change the file where the class is added
data:image/s3,"s3://crabby-images/5f721/5f721f021747c91ad39b391826c4039224fd6da6" alt=""
data:image/s3,"s3://crabby-images/5d730/5d730b32349f7c3ec72839db30dae4d6485ea5a4" alt=""
Chrome DevTools - DOM and styles
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
Computed
data:image/s3,"s3://crabby-images/70a27/70a276dd57ac15a528eb192898b5579fbf7fd30b" alt=""
Useful debugging for a concrete property on a big design system
data:image/s3,"s3://crabby-images/1937b/1937bcbf9ca5a58388eb9ee1dbcb1ebbdcfe5a6c" alt=""
data:image/s3,"s3://crabby-images/b9491/b9491cc8d332af3bf0572a549384e1009fedda46" alt=""
Study box properties and sizes
Chrome DevTools - DOM and styles
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/23d2e/23d2ec95e3b02f8d5a2db3d384624a8175555d6e" alt=""
data:image/s3,"s3://crabby-images/42876/428764f43c44f7a5ce79c1a94ce3f248aef5a4cf" alt=""
data:image/s3,"s3://crabby-images/a709f/a709f6ed1edf3198478f661f45c7d68e8c6c5a8b" alt=""
You can create breakpoints on node modifications!
subtree modifications - stops when any child is modified
attribute modifications - stops when an attr is modified
node removal - stops if the node is removed from DOM
Chrome DevTools - DOM and styles
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/82160/82160245ebb80fc0157699f0a60bf275a6213e06" alt=""
Event Listeners
Event Listeners show you events associated to the selected node
Deactivate Ancestors check in order to avoid info overflow
data:image/s3,"s3://crabby-images/5d730/5d730b32349f7c3ec72839db30dae4d6485ea5a4" alt=""
Chrome DevTools - DOM and styles
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
Accessibility
Can explore a11y node information
Check the role attribute in order to check what people expects from the element
data:image/s3,"s3://crabby-images/00b53/00b535d5f91b9b009347039f314932ed4fb07108" alt=""
data:image/s3,"s3://crabby-images/5d730/5d730b32349f7c3ec72839db30dae4d6485ea5a4" alt=""
Chrome DevTools - DOM and styles
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
Bonus!
Tired of native screenshots?
data:image/s3,"s3://crabby-images/5ac63/5ac6327a78ec26b1f35599b5528b6569ebb04124" alt=""
cmd + shift + P
Chrome DevTools - Performance
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
More tools > Animation
(cmd + shift + p)
data:image/s3,"s3://crabby-images/b7f69/b7f692d0ffe0f081ed0460873a6118f56d54fdf3" alt=""
Chrome DevTools Console
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
Chrome DevTools - Console
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
Console
data:image/s3,"s3://crabby-images/b841c/b841c9832af98796c72134669276a11bd6f8c22b" alt=""
$0 - References the selected HTML element
Execution context from the debugger
Chrome DevTools - Console
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
Console
data:image/s3,"s3://crabby-images/b841c/b841c9832af98796c72134669276a11bd6f8c22b" alt=""
data:image/s3,"s3://crabby-images/d4d99/d4d99561f83f1ebea8145822c5955ad885a4738d" alt=""
❤️ Live expressions
JS statements that executes every 250ms
data:image/s3,"s3://crabby-images/d14bf/d14bfe563688c173be8910fdc931af365f5a09a5" alt=""
Chrome DevTools Sources
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/d01fd/d01fdee904d529ecec77ab309e98999a0803e34b" alt=""
data:image/s3,"s3://crabby-images/8493e/8493e78ec28f2db95cabe7aa4a0a7c184b49079c" alt=""
Client
Inherit code
Chrome DevTools - Sources
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
Sources
data:image/s3,"s3://crabby-images/2c560/2c56057ee5c8ce86d9116810d5c09474d9545917" alt=""
One of the most important and complex areas on DevTools
Show loaded files
Allow us to set breakpoints (not only on js)
Allow us to override entire files!
Blackbox scripts!
Chrome DevTools - Sources
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
Sources
data:image/s3,"s3://crabby-images/2c560/2c56057ee5c8ce86d9116810d5c09474d9545917" alt=""
Page
Show all the context loaded on our browser and all files
All selected files will be shown on the main window, allowing us to set breakpoints
Better to use "Search" tool
data:image/s3,"s3://crabby-images/71ab4/71ab465356a5e1b25578f66d2bcd4bf11f0e5f4b" alt=""
Pretty print!
data:image/s3,"s3://crabby-images/5d730/5d730b32349f7c3ec72839db30dae4d6485ea5a4" alt=""
Chrome DevTools - Sources
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
Filesystem
We can link the served content with our files, and save the edited content!
❤️ Great editing styles
data:image/s3,"s3://crabby-images/bc7d9/bc7d90f97f6bd105e9772ffdafcf436ec8fc9b8a" alt=""
Look for the green point
❤️ Awesome for local development
Chrome DevTools - Sources
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
Overrides
We can replace a served file with a custom and editable file!
- active Enable Local Overrides
- Select the file on network and save for override
❤️ Great for testing new solutions
Look for the purple point
❤️ Awesome for production testing
data:image/s3,"s3://crabby-images/638ea/638ea31361bb898a61d79b094424f60352fdaa1f" alt=""
Chrome DevTools - Sources
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
Threads & Watch
data:image/s3,"s3://crabby-images/c8c0c/c8c0ccfcd68321e808ce8cb5d660e0e6fd1c6814" alt=""
Threads
Useful working with web workers
Can pause both threads at the same time
Watch (deprecated?) > live expressions
Show info about variables values
data:image/s3,"s3://crabby-images/c9956/c99568cfd5a8f6d2d76008b48229a8930624fbf6" alt=""
Chrome DevTools - Sources
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
Breakpoints!
JS breakpoint
data:image/s3,"s3://crabby-images/c8c0c/c8c0ccfcd68321e808ce8cb5d660e0e6fd1c6814" alt=""
Stop JS execution on the selected line or debugger
data:image/s3,"s3://crabby-images/9c469/9c4696c115db019a6330913dca42a66c1c4c46b2" alt=""
data:image/s3,"s3://crabby-images/95f95/95f95bf59fe73e7c872195d89ae96ba71d0cda1c" alt=""
Shows info about the
hovered variable
Chrome DevTools - Sources
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
Breakpoints!
data:image/s3,"s3://crabby-images/c8c0c/c8c0ccfcd68321e808ce8cb5d660e0e6fd1c6814" alt=""
data:image/s3,"s3://crabby-images/8b205/8b205ab2c1333d55e2de1ff91f82deacbf81c0c0" alt=""
data:image/s3,"s3://crabby-images/8b205/8b205ab2c1333d55e2de1ff91f82deacbf81c0c0" alt=""
Pause
Next statement
Jump into/out of function
Next statement (including functions)
data:image/s3,"s3://crabby-images/9ec52/9ec529278ebd9b64a05c169064fd44024c80c4f7" alt=""
data:image/s3,"s3://crabby-images/6663f/6663f75f14b07d5c2ef446c1748d48180bcf16ff" alt=""
data:image/s3,"s3://crabby-images/84bd5/84bd58839038f90800377e9a57971a8cf8968ac5" alt=""
data:image/s3,"s3://crabby-images/d13e1/d13e1176418a699bdc6c1ab32ad3797a5ee97592" alt=""
Chrome DevTools - Sources
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
Breakpoints!
Call Stack
data:image/s3,"s3://crabby-images/c8c0c/c8c0ccfcd68321e808ce8cb5d660e0e6fd1c6814" alt=""
data:image/s3,"s3://crabby-images/fd232/fd23245620cbcd227d1228b2ac979f3d83e722a8" alt=""
Show us all the functions called from the breakpoint
Blackbox the libraries and frameworks!
Scope
Show us the local and global context in the moment of the execution pause so we dont need to hover all props on the source file
Console context becomes the local!
data:image/s3,"s3://crabby-images/5d730/5d730b32349f7c3ec72839db30dae4d6485ea5a4" alt=""
data:image/s3,"s3://crabby-images/5d730/5d730b32349f7c3ec72839db30dae4d6485ea5a4" alt=""
Chrome DevTools - Sources
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
Breakpoints!
XHR Breakpoints
data:image/s3,"s3://crabby-images/c8c0c/c8c0ccfcd68321e808ce8cb5d660e0e6fd1c6814" alt=""
Type a url fragment to stop on xhr request
The Call Stack will show where the request is initiated, allowing us to navigate there
data:image/s3,"s3://crabby-images/7a8f9/7a8f90d820851f0d6af6338628bfdac0b207e375" alt=""
Chrome DevTools - Sources
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
Breakpoints!
DOM elements Breakpoints
data:image/s3,"s3://crabby-images/c8c0c/c8c0ccfcd68321e808ce8cb5d660e0e6fd1c6814" alt=""
Select a HTML Element and select Break on >
The Call Stack will show where the modification is requested, useful using events or toggling attributes
data:image/s3,"s3://crabby-images/a6e94/a6e945580d05d4d5c1af37d273fdcefbec5edeef" alt=""
Chrome DevTools - Sources
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
Breakpoints!
Event Listener Breakpoints
data:image/s3,"s3://crabby-images/c8c0c/c8c0ccfcd68321e808ce8cb5d660e0e6fd1c6814" alt=""
You can activate breakpoints for any kind of event, in order to analize where the application is listening for.
You can see the Global listeners setted too
data:image/s3,"s3://crabby-images/e7665/e7665d54535bf4791ae99ca92d45a0d869e0c716" alt=""
Chrome DevTools Network
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/b13a2/b13a2571d4582bb4d7fc33f489d015257a44f113" alt=""
Blame Backend
data:image/s3,"s3://crabby-images/52b64/52b6434fa13326098d08ce60daf665f401549c30" alt=""
Study your HUGE web
Chrome DevTools - Network
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/7fe44/7fe440fc407a5567bee191d3987521c826e875cd" alt=""
Chrome DevTools - Network
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/9a58b/9a58b0f58dfc81c39ac80e0e1292b4f26c4b66c6" alt=""
We can get request information by clicking it
Check if the request params are ok
Chrome DevTools - Network
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/7fe44/7fe440fc407a5567bee191d3987521c826e875cd" alt=""
data:image/s3,"s3://crabby-images/375d6/375d64b6e1353ddb3090707f5f78133a671b0b6f" alt=""
data:image/s3,"s3://crabby-images/83274/832747b6ea1db32f566c197f68cb8868d587f205" alt=""
Capture screenshots, useful for understand the critical path
data:image/s3,"s3://crabby-images/fbd92/fbd92c3dbe78b0cc92938510b043a9e75dd5e29d" alt=""
Show requests with more information (files weight & more)
data:image/s3,"s3://crabby-images/3b3c0/3b3c0196929b28ca80f45e0c3197d1481a25bcaa" alt=""
Preserve log, useful when quick redirections happens
Disable cache, nice for development and analysis
Chrome DevTools - Network
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/7fe44/7fe440fc407a5567bee191d3987521c826e875cd" alt=""
data:image/s3,"s3://crabby-images/375d6/375d64b6e1353ddb3090707f5f78133a671b0b6f" alt=""
data:image/s3,"s3://crabby-images/ad919/ad9197f15d9fe53c9da2de414a46d44ee7e92b4b" alt=""
One of the best tools on DevTools
Allow us to limit the connection speed
Test like a 3g network or Offline (nice for PWA)
Great for look into the waterfall graph
Slow 3G is too slow...
Can be configure from dev console (cmd + shift + p)
data:image/s3,"s3://crabby-images/5d730/5d730b32349f7c3ec72839db30dae4d6485ea5a4" alt=""
data:image/s3,"s3://crabby-images/5d730/5d730b32349f7c3ec72839db30dae4d6485ea5a4" alt=""
Chrome DevTools - Network
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/375d6/375d64b6e1353ddb3090707f5f78133a671b0b6f" alt=""
With 3G activated, the waterfall is more visible, and with screenshots, we can detect the "prerender" requested sources
data:image/s3,"s3://crabby-images/8581b/8581bae3099a18ea61de6ccbf6a343bc7f12a4c0" alt=""
Chrome DevTools - Network
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/23307/233074e4812c44fef79d6b45d80eb1302361405b" alt=""
data:image/s3,"s3://crabby-images/1d8e5/1d8e541f4b2e75c248bcb9bc890814858e292d6e" alt=""
Block requests by URL or Domain
Allow us to check the web behaviour without the blocked resource
Save for overrides
Magic
Chrome DevTools - Network
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/375d6/375d64b6e1353ddb3090707f5f78133a671b0b6f" alt=""
Check the "Priority" column, in order to see the requests priorities
data:image/s3,"s3://crabby-images/b6a77/b6a775c01a103ab88480491930e70c7a9bf12971" alt=""
data:image/s3,"s3://crabby-images/5d730/5d730b32349f7c3ec72839db30dae4d6485ea5a4" alt=""
Chrome DevTools - Network
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/3d149/3d14902b2179729f346c43515c5ca27912192044" alt=""
Chrome DevTools - Performance
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
More tools > Coverage
(cmd + shift + p)
Check unused CSS & JS
data:image/s3,"s3://crabby-images/d8bb4/d8bb406e4db8f43df4e482f182acdcd40d11ed39" alt=""
Chrome DevTools Performance
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/2474f/2474f545b32b1b181c5ef45783e3dbb2f607d08a" alt=""
Client
50k lines of code
data:image/s3,"s3://crabby-images/8496c/8496cc1c102fa2630d49ddfa7792bfe94c8b3b6f" alt=""
Chrome DevTools - Audits
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/4629b/4629bfe41cae37d23d804ef27706b7d5246db5d1" alt=""
data:image/s3,"s3://crabby-images/511fa/511fa1b93870e14fc80e911fcb1472a3cc8e2b79" alt=""
Chrome DevTools - Audits
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
Now available for CI
data:image/s3,"s3://crabby-images/e55e0/e55e0c52ce957b3c86002e5143eb6290e558e776" alt=""
https://github.com/ebidel/lighthousebot
Chrome DevTools - Performance
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/b1d9f/b1d9f596a1b29263b12f2a57876c59ef295fcdc3" alt=""
The worse config, the better
Check Screenshots for more info without hovering
data:image/s3,"s3://crabby-images/5d730/5d730b32349f7c3ec72839db30dae4d6485ea5a4" alt=""
Click on the gray circle to analyze concrete areas or behaviours, or on the arrow to force a full load
Chrome DevTools - Performance
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/26e7a/26e7a8933767c22c29e01ba10388ab12de4374f2" alt=""
data:image/s3,"s3://crabby-images/767e6/767e67aa2243adc3ccfe82f1abfa1ac22e954459" alt=""
Chrome DevTools - Performance
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
Discover
Analyze
Fix
Chrome DevTools - Performance
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/6f230/6f230e677791ebb67fe6803371902d94798e3d22" alt=""
data:image/s3,"s3://crabby-images/78742/787426a0aa7eddb78fbdff86b20ea59091789505" alt=""
FPS
The green bars show fps during the rendering / animation
data:image/s3,"s3://crabby-images/523f9/523f9806f53c42efe6213b9eec1ab2f8dee1e4ce" alt=""
The redpoints shows bottlenecks or fps problems
data:image/s3,"s3://crabby-images/5d730/5d730b32349f7c3ec72839db30dae4d6485ea5a4" alt=""
CPU
Shows CPU use. Discover critical points
Screenshots will help identifying the critical points
data:image/s3,"s3://crabby-images/5d730/5d730b32349f7c3ec72839db30dae4d6485ea5a4" alt=""
Chrome DevTools - Performance
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/eeec9/eeec91cdaa68c262e647d9c7e70b7fda88b81c55" alt=""
Performance is the art of doing less
Scripting and Rendering
426.2 ms + 279.0 ms
Check colors for info!
requestIdleCallback
requestAnimationFrame
Chrome DevTools - Performance
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/85352/853524f154c420707e327299fd8b82c59de8d595" alt=""
Select a problematic stack call, and analyze
data:image/s3,"s3://crabby-images/0dbb3/0dbb345909eb8eec960a9c80075acd2ea7cabd83" alt=""
Navigate on stack call to detect problematic points
Chrome DevTools - Performance
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/371ff/371ff932730b130a6a4e9b288b3819607367c069" alt=""
More tools > Rendering
(cmd + shift + p)
FPS meter 🧭
Paint flashing 🖼️
Scrolling performance issues 🧶
Chrome DevTools - Performance
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/ae7e7/ae7e76cae30aeecf1e2a862094390ddf844a3955" alt=""
data:image/s3,"s3://crabby-images/5e6a9/5e6a932ac8cf3c8658b4c9e793aa2bf21955487e" alt=""
Chrome has their own Task manager where we can check the consumed memory
Chrome DevTools - Performance
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/56150/56150af9bad399b760b15b2b4e5b078d7e646e36" alt=""
Chrome DevTools - Performance
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
More tools > Performance monitor
(cmd + shift + p)
Check a lot of params
data:image/s3,"s3://crabby-images/2e55d/2e55d01dc97208f07358ca8685a6236d84d3ca2d" alt=""
Chrome DevTools Application
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
Chrome DevTools - Application
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/a0f0e/a0f0e12163bf078aec885838af7fcfba604b1fcb" alt=""
PWA info
Storage
Cache
Frames
Chrome DevTools - Application
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/a0f0e/a0f0e12163bf078aec885838af7fcfba604b1fcb" alt=""
data:image/s3,"s3://crabby-images/f3fc3/f3fc377614e9b68bf97b5570d60a4134a6879b2d" alt=""
Services workers
Manifest
Can test notifications on the fly or force updates
data:image/s3,"s3://crabby-images/5d730/5d730b32349f7c3ec72839db30dae4d6485ea5a4" alt=""
Shows info about the manifest and PWA configuration
Chrome DevTools - Application
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/31f90/31f900e2e664da53a26cd8ac53daf8bf448a5941" alt=""
Golden button for devs
(and clients)
Chrome DevTools - Application
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
data:image/s3,"s3://crabby-images/c0b11/c0b11be491ccd60bb53df4ca7049959b53fd8dcb" alt=""
Shows and allow to modify different storages
Modify access tokens in order to see the "renovation case"
data:image/s3,"s3://crabby-images/5d730/5d730b32349f7c3ec72839db30dae4d6485ea5a4" alt=""
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
Chrome DevTools TOO MUCH
https://bit.ly/2WGbN9q
data:image/s3,"s3://crabby-images/36e94/36e942bb8663d6c47af617c54b07c73dc7912ad9" alt=""
THANK YOU
@JNROJI
https://bit.ly/2WGbN9q
data:image/s3,"s3://crabby-images/f235c/f235c0c65b0699e3d372ce432f35ad55fdd36ed3" alt=""
chrome-devtools
By Jon Rojí
chrome-devtools
- 1,742