The HTML onbeforetoggle event
The HTML onbeforetoggle attribute runs JavaScript when a popover or addEventListener('beforetoggle', …).
Overview
The onbeforetoggle event attribute runs JavaScript just before a popover or beforetoggle — drop the on prefix when you call addEventListener.
It relates to native disclosure and dialog widgets — the <dialog> element, <details>, and popovers — letting you react when they open, close or are dismissed without wiring up the behavior yourself.
You can wire this up with the inline onbeforetoggle HTML attribute, but the modern, recommended approach is element.addEventListener('beforetoggle', handler) in JavaScript. That keeps behavior out of your markup, lets you attach several handlers to the same event, and makes them easy to remove. The inline attribute is fine for quick demos.
Syntax
<element onbeforetoggle="handler()">…</element>
element.addEventListener('beforetoggle', handler);
Best practices
- Prefer
element.addEventListener('beforetoggle', handler)over the inlineonbeforetoggleattribute — it separates behavior from markup and allows multiple handlers. - Prefer the native <dialog>, <details> and popover APIs that fire these events over hand-built widgets.
- Use the event to sync state — for example to lazy-load content when a panel opens.
- Keep these widgets accessible: manage focus and provide an accessible name.
Frequently asked questions
What is the onbeforetoggle event?
beforetoggle.Which elements fire this event?
How do I react when a details element opens?
open property.Should I use the onbeforetoggle attribute or addEventListener?
addEventListener('beforetoggle', …) in JavaScript. The inline onbeforetoggle attribute works but mixes behavior into the markup and allows only one handler per element.