Use watchpoints

When debugging JavaScript code, it can be useful to know when properties on objects are read or modified. In a large, complex codebase, it's not always easy to know where in the code a given property is accessed. In the Firefox Debugger, this information can be provided by watchpoints. By setting a watchpoint on the property, rather than a breakpoint at a particular line, you can discover where that access occurs.Ā 

There are two types of watchpoints: get and set. A get watchpoint pauses whenever a property is read, and a set watchpoint pauses whenever a property value changes.

Set a watchpoint

  1. Run and then pause the debugger.
  2. In the Scopes pane on the right side of the Debugger user interface, find an object you want to watch, and right-click it to open its menu.
  3. Choose Property set or Property get.

    A blue watchpoint icon appears in to the right of the property in the Scopes pane.
  4. Click Play or press F8 to resume execution.

View a watchpoint

When the watched property is accessed in the way specified by the watchpoint type (get or set), the debugger pauses, enabling you to see line of code responsible, and to inspect anything else you wish at that time.

In the following screenshot, the debugger pauses at line 7, where obj.a is set. The message panel in the upper right corner indicates that the debugger is "Paused on property set".

Delete a watchpoint

  1. Locate the watched property in the Scopes pane.
  2. Click the blue watchpoint icon. The watchpoint is removed.

See also