files/en-us/web/api/element/contextmenu_event/index.md
{{APIRef("Pointer Events")}}
The contextmenu event fires when the user attempts to open a context menu. This event is typically triggered by clicking the right mouse button, or by pressing the context menu key.
In the latter case, the context menu is displayed at the bottom left of the focused element, unless the element is a tree, in which case the context menu is displayed at the bottom left of the current row.
Any right-click event that is not disabled (by calling the click event's {{domxref("Event.preventDefault", "preventDefault()")}} method) will result in a contextmenu event being fired at the targeted element.
[!NOTE] An exception to this in Firefox: if the user holds down the <kbd>Shift</kbd> key while right-clicking, then the context menu will be shown without a
contextmenuevent being fired.
Use the event name in methods like {{domxref("EventTarget.addEventListener", "addEventListener()")}}, or set an event handler property.
addEventListener("contextmenu", (event) => { })
oncontextmenu = (event) => { }
A {{domxref("PointerEvent")}}. Inherits from {{domxref("MouseEvent")}}.
{{InheritanceDiagram("PointerEvent")}}
[!NOTE] In earlier versions of the specification, the event type for this event was a {{domxref("MouseEvent")}}. Check browser compatibility for more information.
This interface inherits properties from {{domxref("MouseEvent")}} and {{domxref("Event")}}.
0 to 1, where 0 and 1 represent the minimum and maximum pressure the hardware is capable of detecting, respectively.-1 to 1, where 0 is the neutral position of the control.-90 to 90) between the Y–Z plane and the plane containing both the pointer (e.g., pen stylus) axis and the Y axis.-90 to 90) between the X–Z plane and the plane containing both the pointer (e.g., pen stylus) axis and the X axis.0 to 359.contextmenu eventIn this example, the default action of the contextmenu event is canceled using preventDefault() when the contextmenu event is fired at the first paragraph. As a result, the first paragraph will do nothing when right-clicked, while the second paragraph will show the standard context menu offered by your browser.
[!NOTE] In Firefox, if you hold down the <kbd>Shift</kbd> key while right-clicking, then the context menu is shown without the
contextmenuevent being fired. Therefore, canceling the event does not stop the context menu from being shown.
<p id="noContextMenu">The context menu has been disabled on this paragraph.</p>
<p>But it has not been disabled on this one.</p>
const noContext = document.getElementById("noContextMenu");
noContext.addEventListener("contextmenu", (e) => {
e.preventDefault();
});
{{EmbedLiveSample("Canceling the contextmenu event")}}
{{Specifications}}
{{Compat}}