This is the fifth post in a series of productivity tips and tricks to help you debug web applications with Firefox Devtools. It shows you 5 tips & tricks for working with the Responsive Design Mode in the Firefox Developer Tools.
This is a series I try to keep up with, Iāve gathered so many tricks over the years. If youāve liked this or want to see more, Iām @avolakatos on Twitter, follow me there!
I use the Responsive Design Mode as a quick way to test on mobile, locally, without having to deploy. The throttling capabilities, touch events, and custom sizes make it perfect for my needs. I like the fact that I have the rest of the Developer Tools active side-by-side, without having to connect them to my phone browser, and having to look in 2 separate places to debug. It doesnāt work for complex stuff, like pan and zoom, but itās enough for one finger touch events. Sometimes I use the custom user agent just to see what kind of UA tracking websites do in general. Iām not a fan of the fact that since Firefox 60, automatic reload doesnāt happen for user agent switching or when you enable touch events, but I understand the reasoning behind the feature.
Add custom devices
You can edit the display size in the Responsive Mode of Firefox Developer tools, but if you want to make that a preset youāll have to add a custom device. You can open the device dropdown, and select āEdit listā. That gives you a list of the most common presets, and you can enable/disable the ones you need. If thatās not enough, you can add your own custom device. If you think the default list should be different, Mozilla is maintaining a GitHub repo for that, feel free to submit a PR.
data:image/s3,"s3://crabby-images/3ba9a/3ba9ae4f7338a935f38cfd3a8dc3a9f182e93ce8" alt="Add custom device"
Throttling
You can throttle the speed of your network requests and see how your website loads on different connections. Firefox has a lot of presets useful for mobile devices, with an intuitive name instead of me having to guess what speed a bad 3G connection would be.
data:image/s3,"s3://crabby-images/1e7ea/1e7eab8e132a282cde93a40f427a181268e93ffa" alt="Speed Throttling"
Simulate touch events
You can simulate touch events in the Responsive Design Mode by clicking the little hand icon. It will disable drag-and-drop selection, and enable touch events, including tap and long-tap events. Click events will be turned into tap events and a long-click event will be simulated into a long-tap event, opening the contextual menu.
data:image/s3,"s3://crabby-images/fcc2b/fcc2bb8d7a7daae0f32a73bd4d2808f950476026" alt="Simulate touch events"
Change user agent
You can change the user agent string from the Responsive Design Mode of Firefox DevTools. Youāll have to go to the Settings icon in the top right corner and enable āShow user agentā, and then you can change it in the input field. I personally like to set the āReload when user agent is changedā as well because most websites do their user agent detection on load. You can see here how the Google home page changes when it thinks Iām not an iPhone anymore, and Iām the DuckDuckGo crawling bot š .
data:image/s3,"s3://crabby-images/85596/85596eb67004e8c72dabe356f23c9db44b2354e9" alt="Change user agent"
Left align the Viewport
The Responsive Design Mode is centered by default, and that is all good when Iām only testing. But when Iām debugging, Iād like to be able to us as much of the rest of the screen for the DevTools panel. You can make align the Responsive Design Viewport to the left, by enabling the option in the Settings menu.
data:image/s3,"s3://crabby-images/f82d7/f82d766f98faeb0ebe948b2a5b43d5fbabfab140" alt="Left align the Viewport"