A custom element that is a declarative MutationObserver
for debugging.
Instead of opening your developer tools to set these breakpoints wrap
the element in the <break-on>
custom element. See the demo.
import { BreakOnElement } from "https://esm.sh/gh/knowler/break-on-element/break-on-element.js?raw";
BreakOnElement.define();
<break-on attributes>
<p>Will break on all attribute modifications for this element.</p>
</break-on>
<break-on attributes="class">
<p>Will break on class name modifications for this element.</p>
</break-on>
<break-on attributes="class id">
<p>Will break on class name and ID modifications for this element.</p>
</break-on>
<break-on attributes="class id" subtree>
<p>Will break on class name and ID modifications for this element and its subtree.</p>
</break-on>
<break-on children>
<p>Will break on adding and removing direct descendants.</p>
</break-on>
<break-on children subtree>
<p>Will break on adding and removing all descendants.</p>
</break-on>
<break-on text>
<p>Will break on text changes in the first top-level text node.</p>
</break-on>
<break-on text subtree>
<p>Will break on all text changes within an element.</p>
</break-on>
<break-on selector=":scope > div > p" attributes="class">
<div>
<p>Setting the breakpoint on a nested element</p>
</div>
</break-on>