docs.rodeo

MDN Web Docs mirror

Element: click event

{{APIRef}} 

An element receives a click event when any of the following occurs:

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.

Syntax

Use the event name in methods like {{domxref("EventTarget.addEventListener", "addEventListener()")}} , or set an event handler property.

addEventListener("click", (event) => {});

onclick = (event) => {};

Event type

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.

Event properties

This interface inherits properties from {{domxref("MouseEvent")}}  and {{domxref("Event")}} .

Usage notes

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.

Examples

This example displays the number of consecutive clicks on a {{HtmlElement("button")}} .

HTML

<button>Click</button>

JavaScript

const button = document.querySelector("button");

button.addEventListener("click", (event) => {
  button.textContent = `Click count: ${event.detail}`;
});

Result

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

{{Specifications}} 

Browser compatibility

{{Compat}} 

See also

In this article

View on MDN