The MouseEvent
interface represents events that occur due to the user interacting with a pointing device (such as a mouse). Common events using this interface include click
, dblclick
, mouseup
, mousedown
.
MouseEvent
derives from UIEvent
, which in turn derives from Event
. Though the MouseEvent.initMouseEvent()
method is kept for backward compatibility, creating of a MouseEvent
object should be done using the MouseEvent()
constructor.
Several more specific events are based on MouseEvent
, including WheelEvent
and DragEvent
.
MouseEvent()
MouseEvent
object.This interface also inherits properties of its parents, UIEvent
and Event
.
MouseEvent.altKey
Read only
true
if the alt key was down when the mouse event was fired.MouseEvent.button
Read only
MouseEvent.buttons
Read only The buttons being depressed (if any) when the mouse event was fired.
MouseEvent.clientX
Read only
MouseEvent.clientY
Read only
MouseEvent.ctrlKey
Read only
true
if the control key was down when the mouse event was fired.MouseEvent.metaKey
Read only
true
if the meta key was down when the mouse event was fired.MouseEvent.movementX
Read only
mousemove
event.MouseEvent.movementY
Read only
mousemove
event.MouseEvent.offsetX
Read only
MouseEvent.offsetY
Read only
MouseEvent.pageX
Read only
MouseEvent.pageY
Read only
MouseEvent.region
Read only
null
is returned.MouseEvent.relatedTarget
Read only
The secondary target for the event, if there is one.
MouseEvent.screenX
Read only
MouseEvent.screenY
Read only
MouseEvent.shiftKey
Read only
true
if the shift key was down when the mouse event was fired.MouseEvent.which
Read only
MouseEvent.mozPressure
Read only
0.0
(minimum pressure) and 1.0
(maximum pressure).MouseEvent.mozInputSource
Read only
The type of device that generated the event (one of the MOZ_SOURCE_*
constants listed below). This lets you, for example, determine whether a mouse event was generated by an actual mouse or by a touch event (which might affect the degree of accuracy with which you interpret the coordinates associated with the event).
MouseEvent.webkitForce
Read only
MouseEvent.x
Read only
MouseEvent.clientX
.MouseEvent.y
Read only
MouseEvent.clientY
MouseEvent.WEBKIT_FORCE_AT_MOUSE_DOWN
Read only
MouseEvent.WEBKIT_FORCE_AT_FORCE_MOUSE_DOWN
Read only
This interface also inherits methods of its parents, UIEvent
and Event
.
MouseEvent.getModifierState()
KeyboardEvent.getModifierState
() for details.MouseEvent.initMouseEvent()
MouseEvent
created. If the event has already being dispatched, this method does nothing.This example demonstrates simulating a click (that is programmatically generating a click event) on a checkbox using DOM methods.
function simulateClick() { var evt = new MouseEvent("click", { bubbles: true, cancelable: true, view: window }); var cb = document.getElementById("checkbox"); //element to click on var canceled = !cb.dispatchEvent(evt); if(canceled) { // A handler called preventDefault alert("canceled"); } else { // None of the handlers called preventDefault alert("not canceled"); } } document.getElementById("button").addEventListener('click', simulateClick);
<p><label><input type="checkbox" id="checkbox"> Checked</label> <p><button id="button">Click me</button>
Click on the button to see how the sample works:
Feature | Chrome | Edge | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|---|---|
Basic support | (Yes) | (Yes) | (Yes) | (Yes) | (Yes) | (Yes) |
movementX movementY
| 37 | (Yes) | (Yes) moz | ? | (Yes) | ? |
buttons | 43 | (Yes) | (Yes) | ? | ? | No support |
which | 1 | (Yes) | 1.0 | 9.0 | 5.0 | 1.0 |
getModifierState() | 47 | (Yes) | 15 (15) | (Yes) | (Yes) | (Yes) |
mozPressure and mozInputSource
| No support | ? | 4.0 (2) | No support | No support | No support |
MouseEvent() | 45 | ? | 11 (11) | 9.0 | (Yes) | ? |
MouseEvent.region | 51[1] | ? | 32 (32) | ? | ? | ? |
MouseEvent.offsetX , and MouseEvent.offsetY
| (Yes) | 9 | 40 (40) | ? | ? | ? |
MouseEvent.screenX , MouseEvent.screenY , MouseEvent.clientX , and MouseEvent.Y are double instead of long. | 56 | ? | ? | ? | ? | ? |
Feature | Android | Chrome for Android | Edge | Firefox Mobile (Gecko) | IE Mobile | Opera Mobile | Safari Mobile |
---|---|---|---|---|---|---|---|
Basic support | No support | No support | (Yes) | ? | ? | ? | ? |
[1] Requires enabling the ExperimentalCanvasFeatures
flag.
UIEvent
.
© 2005–2018 Mozilla Developer Network and individual contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/MouseEvent