.. toctree:: :name: devtools-user-doc ========================== Firefox DevTools User Docs ========================== Firefox Developer Tools is a set of web developer tools built into Firefox. You can use them to examine, edit, and debug HTML, CSS, and JavaScript. This section contains detailed guides to all of the tools as well as information on how to debug Firefox for Android, how to extend DevTools, and how to debug the browser as a whole. If you have any feedback on DevTools or want to contribute to the project, you can `join the DevTools community `_. .. note:: If you are just getting started with web development and using developer tools, our `learning `_ docs will help you — see `Getting started with the Web `_ and `What are browser developer tools? `_ for good starting points. The Core Tools ************** You can open the Firefox Developer Tools from the menu by selecting **Tools > Web Developer > Web Developer Tools** or use the keyboard shortcut :kbd:`Ctrl` + :kbd:`Shift` + :kbd:`I` or :kbd:`F12` on Windows and Linux, or :kbd:`Cmd` + :kbd:`Opt` + :kbd:`I` on macOS. The ellipsis menu on the right-hand side of Developer Tools contains several commands that let you perform actions or change tool settings. .. figure:: devtools_layoutmenu.png :align: center ========== ================================================================ |image1| This button only appears when there are multiple iframes on a page. Click it to display a list of the iframes on the current page and select the one with which you want to work. |image2| Click this button to take a screenshot of the current page. (*Note:* This feature is not turned on by default and must be enabled in settings before the icon will appear.) |image3| Toggles Responsive Design Mode |image4| Opens the menu that includes docking options, the ability to show or hide the split console, and Developer Tools settings. The menu also includes links to the documentation for Firefox Web Tools and the Mozilla Community. |image5| Closes the Developer Tools ========== ================================================================ .. |image1| image:: iframe_button.png :class: center .. |image2| image:: camera_button.png :class: center .. |image3| image:: responsive_button.png :class: center .. |image4| image:: menu_button.png :class: center .. |image5| image:: close_button.png :class: center Page Inspector -------------- .. image:: landingpage_pageinspector.png :class: border :target: page_inspector :alt: The all-new Inspector panel in Firefox 57. View and edit page content and layout. Visualize many aspects of the page including the box model, animations, and grid layouts Web Console ----------- .. image:: landingpage_console.png :class: border :target: web_console :alt: The all-new Console panel in Firefox 57. See messages logged by a web page and interact with the page using JavaScript. JavaScript Debugger ------------------- .. image:: landingpage_debugger.png :class: border :target: debugger :alt: The all-new Debugger panel in Firefox 57. Stop, step through, and examine the JavaScript running on a page. Network Monitor --------------- .. image:: landingpage_network.png :class: border :target: network_monitor :alt: The Network panel in Firefox 57 DevTools. See the network requests made when a page is loaded. Performance Panel ----------------- .. image:: landingpage_performance_2022.png :class: border :target: https://profiler.firefox.com/docs/ :alt: Performance Panel in Firefox 103 Developer Tools. Analyze your site's general responsiveness, JavaScript, and layout performance. Responsive Design Mode ---------------------- .. image:: landingpage_responsivedesign.png :class: border :target: responsive_design_mode :alt: Responsive Design mode in Firefox 57 Developer Tools. See how your website or app will look and behave on different devices and network types. Accessibility inspector ----------------------- .. image:: landingpage_accessibility.png :class: border :target: accessibility_inspector :alt: Performance Tools in Firefox 57 Developer Tools. Provides a means to access the page's accessibility tree, allowing you to check what's missing or otherwise needs attention. Application panel ----------------- .. image:: just-application-panel.png :class: border :target: application :alt: Performance Tools in Firefox 57 Developer Tools. Provides tools for inspecting and debugging modern web apps (also known as `Progressive Web Apps `_). This includes inspection of `service workers `_ and `web app manifests `_ .. note:: The collective term for the UI inside which the DevTools all live is the :doc:`Toolbox ` More Tools ********** These developer tools are also built into Firefox. Unlike the "Core Tools" above, you might not use them every day. .. list-table:: :widths: 25 75 :header-rows: 0 * - :doc:`Memory ` - Figure out which objects are keeping memory in use. * - :doc:`Storage Inspector ` - Inspect cookies, local storage, indexedDB, and session storage present in a page. * - :doc:`DOM Property Viewer ` - Inspect the page's DOM properties, functions, etc. * - :doc:`Eyedropper ` - Select a color from the page. * - :doc:`Style Editor ` - View and edit CSS styles for the current page. * - :doc:`Taking screenshot ` - Take a screenshot of the entire page or of a single element. * - :doc:`Measure a portion of the page ` - Measure a specific area of a web page. * - :doc:`Rulers ` - Overlay horizontal and vertical rulers on a web page * - :doc:`Custom formatters ` - Customize the way objects are displayed within the DevTools. * - :doc:`JavaScript tracer ` - Live display all JavaScript function calls. .. image:: logo-developer-quantum.png :class: center .. rst-class:: center For the latest developer tools and features, try Firefox Developer Edition. `Download Firefox Developer Edition `_ Connecting the Developer Tools ****************************** If you open the developer tools using :ref:`keyboard shortcuts ` or the equivalent menu items, they'll target the document hosted by the currently active tab. But you can attach the tools to a variety of other targets, too, both within the current browser and in different browsers or even different devices. .. list-table:: :widths: 30 70 :header-rows: 0 * - :doc:`about:debugging ` - Debug add-ons, content tabs, and workers running in the browser. * - :ref:`Connecting to Firefox for Android ` - Connect the developer tools to an instance of Firefox running on an Android device. * - :doc:`Connecting to iframes ` - Connect the developer tools to a specific iframe in the current page. Debugging the browser ********************* By default, the developer tools are attached to a web page or web app. But you can also connect them to the browser as a whole. This is useful for browser and add-on development. .. list-table:: :widths: 30 70 :header-rows: 0 * - :doc:`Browser Console ` - See messages logged by the browser itself and by add-ons, and run JavaScript code in the browser's scope. * - :doc:`Browser Toolbox ` - Attach the Developer Tools to the browser itself. Extending DevTools ****************** For information on extending the Firefox DevTools, see `Extending the developer tools `_ over in the `Browser Extensions `_ section of MDN. Migrating from Firebug ********************** Firebug has come to the end of its lifespan (see `Firebug lives on in Firefox DevTools `_ for details of why), and we appreciate that some people will find migrating to another less familiar set of DevTools to be challenging. To ease a transition from Firebug to the Firefox developer tools, we have written a handy guide — :doc:`Migrating from Firebug <./migrating_from_firebug/index>` Contribute ********** If you want to help improve the developer tools, these resources will get you started. .. list-table:: :widths: 30 70 :header-rows: 0 * - `Get Involved `_ - Our community website explains how to get involved. * - `bugs.firefox-dev.tools `_ - A tool helping to find bugs to work on. * - :ref:`Read source docs ` - Firefox DevTools source code documentation.