--- title: MouseEvent slug: Web/API/MouseEvent tags: - API - DOM - DOM Events - Interface - Precisa de Tradução - Referencia - TopicStub translation_of: Web/API/MouseEvent ---
A interface MouseEvent
representa eventos que ocorrem devido à interação do usuário com um dispositivo apontador (como um mouse). Eventos comuns usando esta interface incluem click
, dblclick
, mouseup
, mousedown
.
MouseEvent
deriva de UIEvent
, que por sua vez deriva de Event
. Embora o método MouseEvent.initMouseEvent()
seja mantido para compatibilidade com versões anteriores, a criação de um objeto MouseEvent
deve ser feita usando o construtor MouseEvent()
.
Vários eventos mais específicos derivam de MouseEvent
como: WheelEvent
e DragEvent
.
{{InheritanceDiagram}}
MouseEvent()
MouseEvent
.Essa interface também herda propriedades de seus pais, UIEvent
e Event
.
MouseEvent.altKey
Read only
true
se a tecla alt estava pressionada quando o evento do mouse foi disparado.MouseEvent.button
Read only
MouseEvent.buttons
Read only Os botões sendo pressionados (se houver) quando o evento do mouse foi disparado.
MouseEvent.clientX
Read only MouseEvent.clientY
Read only MouseEvent.ctrlKey
Read only true
se a tecla control estava pressionada quando o evento do mouse foi disparado.MouseEvent.metaKey
Read only true
se a tecla meta estava pressionada quando o evento do mouse foi disparado.mousemove
.MouseEvent.movementY
Read only MouseEvent.offsetX
Read only MouseEvent.offsetY
Read only MouseEvent.pageX
Read only MouseEvent.pageY
Read only MouseEvent.region
Read only null
será retornado.MouseEvent.relatedTarget
Read only O destino secundário do evento, se houver.
MouseEvent.screenY
Read only true
se a tecla shift estava pressionada quando o evento do mouse foi disparado.MouseEvent.mozPressure
Read only 0.0
(pressão mínima) e 1.0
(pressão máxima).MouseEvent.mozInputSource
Read only O tipo de dispositivo que gerou o evento (uma das constantes MOZ_SOURCE_*
listadas abaixo). Isso permite, por exemplo, determinar se um evento de mouse foi gerado por um mouse real ou por um evento de toque (o que pode afetar o grau de precisão com que você interpreta as coordenadas associadas ao evento).
MouseEvent.webkitForce
Read only MouseEvent.clientX
.MouseEvent.y
Read only MouseEvent.WEBKIT_FORCE_AT_MOUSE_DOWN
Read only MouseEvent.WEBKIT_FORCE_AT_FORCE_MOUSE_DOWN
Read only Essa interface também herda métodos de seus pais, UIEvent
e Event
.
MouseEvent.getModifierState()
KeyboardEvent.getModifierState
()
para obter detalhes.MouseEvent.initMouseEvent()
MouseEvent
criado. Se o evento já foi despachado, este método não faz nada.Este exemplo demonstra a simulação de um clique (que está gerando programaticamente um evento de clique) em uma caixa de seleção usando métodos DOM.
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>
Clique no botão para ver como funciona a amostra:
{{EmbedLiveSample('Example')}}
Specification | Status | Comment |
---|---|---|
{{SpecName('CSSOM View','#extensions-to-the-mouseevent-interface', 'MouseEvent')}} | Rascunho de trabalho | Redefine MouseEvent de longo para duplo. Isto significa que um PointerEvent cuja pointerType é rato será uma de casal. |
{{SpecName("HTML WHATWG", "#dom-mouseevent-region", "MouseEvent.region")}} | {{Spec2('HTML WHATWG')}} | Do Document Object Model (DOM) Nível 3 Events Specification , adicionado propriedades movementX e movementY . |
{{SpecName('Pointer Lock','#extensions-to-the-mouseevent-interface','MouseEvent')}} | {{Spec2('Pointer Lock')}} | |
{{SpecName('CSSOM View', '#extensions-to-the-mouseevent-interface', 'MouseEvent')}} | {{Spec2('CSSOM View')}} | A partir do documento de modelo de objeto (DOM) Nível 3 Especificação de eventos , adicionados offsetX e offsetY , pageX e pageY , x , e y propriedades. Propriedades redefinidas de tela, página, cliente e coordenadas (x e y) a partir double de long . |
{{SpecName('DOM3 Events','#events-mouseevents','MouseEvent')}} | {{Spec2('DOM3 Events')}} | Em Document Object Model (DOM) Nível 2, especificação de eventos, adicionado ao construtor MouseEvent () , o método getModifierState() e a propriedade de buttons . |
{{SpecName('DOM2 Events','#Events-MouseEvent','MouseEvent')}} | {{Spec2('DOM2 Events')}} | Definição inicial. |
{{ CompatibilityTable() }}
Feature | Chrome | Edge | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|---|---|
Basic support | {{CompatVersionUnknown()}} | {{CompatVersionUnknown()}} | {{CompatVersionUnknown()}} | {{CompatVersionUnknown()}} | {{CompatVersionUnknown()}} | {{CompatVersionUnknown()}} |
{{domxref("MouseEvent.movementX","movementX")}} {{domxref("MouseEvent.movementY","movementY")}} |
{{CompatChrome(37)}} | {{CompatVersionUnknown()}} | {{CompatVersionUnknown()}} {{property_prefix("moz")}} | {{ CompatUnknown() }} | {{CompatVersionUnknown()}} | {{ CompatUnknown() }} |
{{ domxref("MouseEvent.buttons", "buttons") }} | {{CompatChrome(43)}} | {{CompatVersionUnknown()}} | {{ CompatVersionUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{CompatNo}} |
{{ domxref("MouseEvent.which", "which") }} | {{CompatChrome(1)}} | {{CompatVersionUnknown()}} | 1.0 | 9.0 | 5.0 | 1.0 |
{{domxref("MouseEvent.getModifierState()", "getModifierState()")}} | {{CompatChrome(47)}} | {{CompatVersionUnknown()}} | {{CompatGeckoDesktop(15)}} | {{CompatVersionUnknown()}} | {{CompatVersionUnknown()}} | {{CompatVersionUnknown()}} |
{{domxref("MouseEvent.mozPressure", "mozPressure")}} and {{domxref("MouseEvent.mozInputSource", "mozInputSource")}} {{non-standard_inline}} | {{CompatNo}} | {{ CompatUnknown() }} | {{CompatGeckoDesktop(2)}} | {{CompatNo}} | {{CompatNo}} | {{CompatNo}} |
{{domxref("MouseEvent.MouseEvent", "MouseEvent()")}} | {{CompatChrome(45)}} | {{ CompatUnknown() }} | {{CompatGeckoDesktop(11)}} | 9.0 | {{CompatVersionUnknown()}} | {{ CompatUnknown() }} |
{{domxref("MouseEvent.region")}} | {{CompatChrome(51)}}[1] | {{ CompatUnknown() }} | {{CompatGeckoDesktop(32)}} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} |
{{domxref("MouseEvent.offsetX")}}, and {{domxref("MouseEvent.offsetY")}} | {{CompatVersionUnknown()}} | 9 | {{CompatGeckoDesktop(40)}} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} |
{{domxref("MouseEvent.screenX")}}, {{domxref("MouseEvent.screenY")}}, {{domxref("MouseEvent.clientX")}}, and {{domxref("MouseEvent.Y")}} are double instead of long. | {{CompatChrome(56)}} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} |
Feature | Android | Chrome for Android | Edge | Firefox Mobile (Gecko) | IE Mobile | Opera Mobile | Safari Mobile |
---|---|---|---|---|---|---|---|
Basic support | {{CompatNo}} | {{CompatNo}} | {{CompatVersionUnknown}} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} | {{ CompatUnknown() }} |
[1] Requires enabling the ExperimentalCanvasFeatures
flag.
Seu pai direto, UIEvent
.
PointerEvent
: Para eventos de ponteiro avançados, incluindo multitoque