Chrome DevTools is the one we use most often in front-end debugging. Before reading “modern front-end technology analysis” this book, there is such a sentence.

In Chrome, a good front end engineer needs to be at least 95 percent familiar with the controls and content when opening the console with F12.

95% is a bit high, but it illustrates the importance of using debugging tools. Therefore, I took time to read the Document in DevTools to strengthen my debugging ability.

HTML, CSS,

  • Alt + Click expands all HTML nodes

Sometimes HTML has a lot of nodes. In addition to directly examining (Ctrl + Shift + C) the page element to locate, you can also expand it by Alt + Click.

  • Use filters in the Styles and Computed TAB fields

  • Shortcuts for changing CSS values

    • Alt+Up + 0.1
    • Up + 1
    • Shift+Up + 10
    • Ctrl+Up + 100
  • In the Style column,.cls can add a new class name or switch

I think it is too stupid to debug the class name and change the style in the left DOM node.

  • More operation toolbar

This is used when adding colors and shadows

  • Color choices

The Straw tool can be used to get the color of a page. If you want to get the color of a page and don’t have chrome installed, try this method

JavaScript

  • You can edit the JavaScript code directly from the DevTools UI, saving the changes with Ctrl+S

This method usually only changes code that is executed repeatedly, and then reverts to the original code if it is refreshed only once.

  • Pause the code with breakpoints
Breakpoint types Usage scenarios
Line breakpoints Code for a specific area
Conditional line breakpoint Code for a specific area, but only under certain conditions
DOM Changes, removes elements, or removes child nodes
XHR The URL contains a string
Event listeners Emitted after the event is executed
abnormal Exceptions thrown or not thrown
function Debug (fn) when a particular function executes

Here’s how you might not use the breakpoint method:

Conditional Line Breakpoint: Right-click in the left line number area and select Add Conditional BreakPoint.

DOM changes breakpoints:

XHR breakpoint: A breakpoint is broken at the XHR request place when a request contains a string.

Event listening breakpoints: Breakpoints are generated after an event is triggered

Function breakpoint:

function sum(a, b) {
  let result = a + b; // DevTools pauses on this line.
  return result;
}
debug(sum); // Pass the function object, not a string.
sum();
Copy the code
  • Some code is ignored in debugging
    • Open the file, right-click and select Blackbox Script
    • From the execution stack, right-click the operation

If you can ensure that the third party library is ok, debugging can directly ignore the file, step out of the time faster.

  • Format compressed files

Log

  • The $() is the document querySelector ()

Find elements in the console as quickly as jquery

  • $0 returns the most recently selected element or JavaScript object

  • Console.table () is printed as a table, usually with the list value returned by the back end

  • Console.dir () displays all of an object’s properties and methods.

This is usually used to output DOM elements or objects. Another trick is to print the properties and methods of the native object console.dir(Number).

  • Keys (object) Gets all the keys of an object

  • Console.group () console.groupend () console.groupcollapsed () Information is displayed on the console in groups

  • Console.count () number of function calls

  • Console.time () and console.timeend () track the elapsed time between code execution points.

  • GetEventListeners get all event listeners on the Document element

conclusion

Debugging tools still have analysis running performance, analysis of network conditions, analysis of memory conditions, these practical is stronger, it is best to go to see their own documents, in the search for a few projects to practice.

In fact, you may have read the official documentation, but the usual debugging is still the same as before, so you still need to think about better debugging methods in debugging, of course, the premise is that you have been exposed to these methods.