Using Chrome Devtools
Topics covered
- The Elements and console panel
- The Network panel
- Rendering, performance and Rails
Elements: review the html and css
Chrome devtools: Overall anatomy
data:image/s3,"s3://crabby-images/1c344/1c3444e9d9d89fa5f734a56e20dfd44a45ad212e" alt=""
Elements: examine and edit css
Chrome devtools: Elements panel
data:image/s3,"s3://crabby-images/76d0d/76d0d2fa228e38a98c33f5e9ebaf404f11c5ff3d" alt=""
Elements: view local change history
Chrome devtools: Elements panel
data:image/s3,"s3://crabby-images/827e0/827e00fecd7c9ec334dc29dda7e4eefa7b841d42" alt=""
data:image/s3,"s3://crabby-images/a5a61/a5a61aa2abaef710ab03586fd61314d09f09b90b" alt=""
Elements: examine event handlers
Chrome devtools: Elements panel
data:image/s3,"s3://crabby-images/72241/722411213e42b46c2a80e3815361fed5e1e924b5" alt=""
Console: debug javascript
Chrome devtools: Console panel
data:image/s3,"s3://crabby-images/d9c41/d9c41117167916f533e2af3db19da86766dcec90" alt=""
Note:
- Frames are separated environments in console
- This is Chrome's JS runtime (v8) . May not apply to our production runtime (exec.js)
Console: thing to notice
Chrome devtools: Overall anatomy: panels
data:image/s3,"s3://crabby-images/3090b/3090b178b4017f15c001c9c78b20f3f025101ab0" alt=""
- We can clear the console
- We can filter the output (filter panel not open by default)
- We can switch to iFrames
- We can persist the console (otherwise it clears on reload)
1
2
3
4
Console: utilities
Chrome devtools: Overall anatomy: panels
$(css_selector) | gives first match (!= JQuery) |
$$(css-selector) | gives all matches |
$x(xpath) | gives all matches |
$_ | last output |
$0 ... $4 | last five used elements |
copy(object) | copies object to clipboard |
dir(object) | directory style listing (good for Dom) |
inspect(object) | opens Element panel with object selected |
getEventListeners(object) | shows all event listeners on the object |
keys(object) | lists names of properties |
monitor(function) | logs on console when function is called |
monitorEvents(object, events) | logs Event object when event occurs on the object |
table(data) | Log object data with table formatting |
values(object) | array containing the values of all properties |
Ref: https://developers.google.com/web/tools/chrome-devtools/debug/command-line/command-line-reference?hl=en
Console: $0
Chrome devtools: Console panel
$0 gives the currently selected element in Elements panel
data:image/s3,"s3://crabby-images/5a48e/5a48efde80370944fe3288671cdc78dad27573b7" alt=""
Thanks to https://hackernoon.com/twelve-fancy-chrome-devtools-tips-dc1e39d10d9d#.t3icnbhze
Console: $
Chrome devtools: Console panel
$0 gives the first selected element. No Jquery
data:image/s3,"s3://crabby-images/13b17/13b1733c278aa75753a3dcc473623bdb92da2af0" alt=""
Console: copy
Chrome devtools: Console panel
Copy the object to the clipboard
copy($0)
Console: $_
Chrome devtools: Console panel
Shows the last result
$_
Console: monitor
Chrome devtools: Console panel
console.log when the function is called
function foo() { }
monitor(foo)
data:image/s3,"s3://crabby-images/a5ea9/a5ea9a3f32544a2d68549e94418e62fc0d1004a7" alt=""
Console: some examples
Chrome devtools: Overall anatomy: panels
var names = {
0: { nick: "Ji", person: "Praveen" },
1: { nick: "Jeev", person: "J.P Robinson" } };
table(names);
monitorEvents(window, "resize");
function foo() { return "foo";}
monitor(foo);
getEventListeners(document);
document.body;
dir(document.body);
copy(names);
$('img');
$$('img');
$_
$0
$1
$2
$3
$4
i=$('img');
inspect(i);
Sources Panel
Sources: general view
Chrome devtools: Sources panel
data:image/s3,"s3://crabby-images/1985d/1985dbd5ee048b1477cac634fda04ebf35fd509e" alt=""
Sources: CMD+P (like Sublime)
Chrome devtools: Sources panel
data:image/s3,"s3://crabby-images/b5c74/b5c7474444f04d9a53d831e05e04e7dc04f6d553" alt=""
Cmd/Ctrl P
Format it
Sources: Make it pretty
Chrome devtools: Overall anatomy: panels
data:image/s3,"s3://crabby-images/12bb7/12bb7ec9ef418b082c51c2d0cb6c6d86baa8839f" alt=""
The network panel
The network panel
Chrome devtools
data:image/s3,"s3://crabby-images/3d759/3d7595d1bf5ee51a0cd1907886aecd4dde0280a3" alt=""
Customisations
Chrome devtools: Network panel
data:image/s3,"s3://crabby-images/e9e0b/e9e0b419d11a29cb2b2e9894c6de228adda1e3fe" alt=""
Disable the cache
Show Overview
Use small request rows
Capture screenshots
Customisations
Chrome devtools: Network panel
data:image/s3,"s3://crabby-images/0f049/0f049f7cc5979afc6287fb57589fd752faa80534" alt=""
Add Domain column (right click here to add get the menu)
Chrome devtools: Network panel: example
data:image/s3,"s3://crabby-images/ca4cd/ca4cde7fd26ad27a5095d6a26ad19c9527c0f305" alt=""
overview
Chrome devtools: Network panel: example2
data:image/s3,"s3://crabby-images/8cb80/8cb80591c0e51a8fa5d4293db9a67be367e57118" alt=""
Chrome devtools: Network panel: with filmstrip
data:image/s3,"s3://crabby-images/36169/3616951cb632494dd070de1094cfcc0d8654eda6" alt=""
Chrome devtools: Network panel: with filmstrip
Detailed view
data:image/s3,"s3://crabby-images/aaf8d/aaf8d46efa4adbdd52583e0f4041bc705ada40be" alt=""
Timestamp
(around DomContentLoaded here)
Things to Notice
Chrome devtools: Network panel
- No. of requests (The bottom bar)
- The blue line (DOMContentLoaded)
- The red line (load)
- Size and Time columns
- The document gap
- The timeline
- The statuses (try w/o disabling cache)
Chrome devtools: Network panel: Things to notice
data:image/s3,"s3://crabby-images/bb8fe/bb8fe9596eef539010b3c19cc16877d696840b00" alt=""
DOMContentLoaded
DOMContentLoaded
Load
Load
Total requests
Statuses
Chrome devtools: Network panel: Things to notice
data:image/s3,"s3://crabby-images/fb763/fb7635b4c470d7cf1d4a85018e26eebc3c6092c6" alt=""
Zoomed in
The 'gap'
Sizes and Times
Rendering mechanics
Chrome devtools: Network panel
- HTMLs are fetched first (Doc)
- A HTML is parsed from top to bottom
- If a resource is invoked along the way, a request may be fired
- Resource may be Js, Css, Image, Font, Media etc
- For Js, the script is loaded and executed before it HTML parsing can continue (by default)
- Resources can be fetched in parallel
- There is a limit to number of parallel connections (TCP, 6) per domain.
Rendering mechanics : performance impact
Chrome devtools: Network panel
- Too many resources will slow down the page (unless its HTTP-2)
- Javascripts on top of the page can block rest of the page. Not if its on the bottom (application.js)
- Scripts/Css/Images consolidated across one file (asset-precompile, css-sprites) will work faster
- External scripts (Olark, Gmap, Analytics will add to load time)
Network timeline details
Chrome devtools: Network panel
-
The anatomy
- Queueing, Stalled
- DNS Lookup, SSL
- Green: TTFB (~ same as server response time)
- Blue: Content Download (~ the size of resource)
-
What to look for?
- Big green - server side needs work
- Big Blue - content size need work
- Unusual value of DNS, SSL
Network timeline
Chrome devtools: Network panel
data:image/s3,"s3://crabby-images/ec7ad/ec7ad2f5e04f3be337c822cc6c9b56a83d759bb2" alt=""
Stalled/Queued
Content download
TTFB
Gaps
Network timeline: TTFB
Chrome devtools: Network panel
data:image/s3,"s3://crabby-images/74c17/74c17ca08006a080c4ed2792d40f4cb26534cbd6" alt=""
More green: Slow network or slow serverside
Network timeline
Chrome devtools: Network panel
data:image/s3,"s3://crabby-images/38b25/38b257e1e55787056077b823b6fa7fe7eceaa3d8" alt=""
More blue: Heavy resource
Chrome devtools: Network panel: Tips
- Multi-select relevant tabs (eg: JS and Xhr)
- Zoom-in using Overview part
- Take screenshots
- Use Throttling to check responsive sites
- Sort by Size and Time to look for heavy resources
Chrome devtools: Network panel: Some Limitations
Limitations
- Network panel does not show javascript execution time
- Exact times are less useful - depend on network/computer
With Rails
Chrome devtools: Network panel
- Place application.js at the bottom if possible
- Use defer/async where possible
- Disallow inline Js
- Localize font css
- Use CDN
- Look for external references from css (esp in libraries)
easier said than done :)
Thanks
@h6165
Abhishek Yadav
ரூபீ ப்ரோக்ராமர்
Co-organizer: Chennai.rb
Chrome devtools-2
By Abhishek Yadav
Chrome devtools-2
- 1,584