files/en-us/web/api/element/click_event/index.md
{{APIRef("UI Events")}}
An element receives a click event when any of the following occurs:
tabindex attribute.If the button is pressed on one element and the pointer is moved outside the element before the button is released, the event is fired on the most specific ancestor element that contained both elements.
click fires after both the {{domxref("Element/mousedown_event", "mousedown")}} and {{domxref("Element/mouseup_event", "mouseup")}} events have fired, in that order.
The event is a device-independent event — meaning it can be activated by touch, keyboard, mouse, and any other mechanism provided by assistive technology.
Use the event name in methods like {{domxref("EventTarget.addEventListener", "addEventListener()")}}, or set an event handler property.
addEventListener("click", (event) => { })
onclick = (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.The {{domxref("PointerEvent")}} object passed into the event handler for click has its {{domxref("UIEvent/detail", "detail")}} property set to the number of times the {{domxref("Event.target", "target")}} was clicked. In other words, detail will be 2 for a double-click, 3 for triple-click, and so forth. This counter resets after a short interval without any clicks occurring; the specifics of how long that interval is may vary from browser to browser and across platforms. The interval is also likely to be affected by user preferences; for example, accessibility options may extend this interval to make it easier to perform multiple clicks with adaptive interfaces.
This example displays the number of consecutive clicks on a {{HtmlElement("button")}}.
<button>Click</button>
const button = document.querySelector("button");
button.addEventListener("click", (event) => {
button.textContent = `Click count: ${event.detail}`;
});
Try making rapid, repeated clicks on the button to increase the click count. If you take a break between clicks, the count will reset.
{{EmbedLiveSample("Examples")}}
{{Specifications}}
{{Compat}}