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:
| Desktop | ||||||
|---|---|---|---|---|---|---|
| Chrome | Edge | Firefox | Internet Explorer | Opera | Safari | |
| Basic support | Yes | Yes | Yes | Yes | Yes | Yes |
MouseEvent() constructor |
47 | ? | 11 | No | Yes | Yes |
altKey |
Yes | Yes | Yes | Yes | Yes | Yes |
button |
1 | Yes | 1 | 9
|
Yes | 3.1 |
buttons |
43 | Yes | Yes
|
9 | Yes | No |
clientX |
Yes | Yes | Yes | 6 | Yes | Yes |
clientY |
Yes | Yes | Yes | 6 | Yes | Yes |
ctrlKey |
Yes | Yes | Yes | Yes | Yes | Yes |
getModifierState |
47 | Yes | ? | ? | ? | ? |
initMouseEvent
|
Yes | Yes | Yes | ? | Yes | ? |
metaKey |
Yes | Yes | Yes | Yes | Yes | Yes |
movementX |
37
|
Yes | 41
|
No | ? | No |
movementY |
37
|
Yes | 41
|
No | ? | No |
offsetX
|
Yes | Yes | 39 | 6 | Yes | Yes |
offsetY
|
Yes | Yes | 39 | 6 | Yes | Yes |
pageX
|
45 | Yes | Yes | 9 | Yes | Yes |
pageY
|
45 | Yes | Yes | 9 | Yes | Yes |
region |
Yes
|
? | 30
|
No | No | No |
relatedTarget |
Yes | Yes | 48 | Yes | Yes | Yes |
screenX |
Yes | Yes | Yes | 6 | Yes | Yes |
screenY |
Yes | Yes | Yes | 6 | Yes | Yes |
shiftKey |
Yes | Yes | Yes | Yes | Yes | Yes |
which
|
1 | Yes | 1
|
9 | 5 | 1 |
x
|
Yes | Yes | 53 | 6 | Yes | Yes |
y
|
Yes | Yes | 53 | 6 | Yes | Yes |
| Mobile | |||||||
|---|---|---|---|---|---|---|---|
| Android webview | Chrome for Android | Edge Mobile | Firefox for Android | Opera for Android | iOS Safari | Samsung Internet | |
| Basic support | Yes | Yes | Yes | Yes | Yes | Yes | ? |
MouseEvent() constructor |
47 | 47 | ? | 14 | Yes | Yes | ? |
altKey |
? | ? | Yes | ? | ? | ? | ? |
button |
? | ? | Yes | ? | ? | ? | ? |
buttons |
No | No | Yes | ? | ? | No | ? |
clientX |
Yes | Yes | Yes | Yes | Yes | Yes | ? |
clientY |
Yes | Yes | Yes | Yes | Yes | Yes | ? |
ctrlKey |
? | ? | Yes | ? | ? | ? | ? |
getModifierState |
47 | 47 | Yes | ? | ? | ? | ? |
initMouseEvent
|
Yes | Yes | Yes | Yes | Yes | ? | ? |
metaKey |
? | ? | Yes | ? | ? | ? | ? |
movementX |
37 | 37
|
Yes | 41
|
? | No | ? |
movementY |
37 | 37
|
Yes | 41
|
? | No | ? |
offsetX
|
Yes | Yes | Yes | 43 | ? | ? | ? |
offsetY
|
Yes | Yes | Yes | 43 | ? | ? | ? |
pageX
|
45 | 45 | Yes | ? | ? | ? | ? |
pageY
|
45 | 45 | Yes | ? | ? | ? | ? |
region |
No | No | ? | 30
|
No | No | ? |
relatedTarget |
? | ? | Yes | ? | ? | ? | ? |
screenX |
Yes | Yes | Yes | Yes | Yes | Yes | ? |
screenY |
Yes | Yes | Yes | Yes | Yes | Yes | ? |
shiftKey |
? | ? | Yes | ? | ? | ? | ? |
which
|
Yes | Yes | Yes | 4
|
Yes | Yes | ? |
x
|
? | ? | Yes | 53 | ? | ? | ? |
y
|
? | ? | Yes | 53 | ? | ? | ? |
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