--- title: MouseEvent.button slug: Web/API/MouseEvent/button translation_of: Web/API/MouseEvent/button ---
{{APIRef("DOM Events")}}
MouseEvent.button是只读属性,它返回一个值,代表用户按下并触发了事件的鼠标按键。
这个属性只能够表明在触发事件的单个或多个按键按下或释放过程中哪些按键被按下了。因此,它对判断{{event("mouseenter")}}, {{event("mouseleave")}}, {{event("mouseover")}}, {{event("mouseout")}} {{event("mousemove")}}这些事件并不可靠。
用户可能会改变鼠标按键的配置,因此当一个事件的MouseEvent.button值为0时,它可能不是由物理上设备最左边的按键触发的。但是对于一个标准按键布局的鼠标来说就会是左键。
注意:{{domxref("MouseEvent.buttons")}} 属性可指示任意鼠标事件中鼠标的按键情况,因此不要把它和MouseEvent.button属性弄混淆了。
var buttonPressed = instanceOfMouseEvent.button
一个数值,代表按下的鼠标按键:
0:主按键,通常指鼠标左键或默认值(译者注:如document.getElementById('a').click()这样触发就会是默认值)
1:辅助按键,通常指鼠标滚轮中键2:次按键,通常指鼠标右键3:第四个按钮,通常指浏览器后退按钮4:第五个按钮,通常指浏览器的前进按钮
对于配置为左手使用的鼠标,按键操作将正好相反。此种情况下,从右至左读取值。
<button id="button" oncontextmenu="event.preventDefault();">Click here with your mouse...</button> <p id="log"></p>
let button = document.querySelector('#button');
let log = document.querySelector('#log');
button.addEventListener('mouseup', logMouseButton);
function logMouseButton(e) {
if (typeof e === 'object') {
switch (e.button) {
case 0:
log.textContent = 'Left button clicked.';
break;
case 1:
log.textContent = 'Middle button clicked.';
break;
case 2:
log.textContent = 'Right button clicked.';
break;
default:
log.textContent = `Unknown button code: ${e.button}`;
}
}
}
{{EmbedLiveSample("示例")}}
| Specification | Status | Comment |
|---|---|---|
| {{SpecName('DOM3 Events','#widl-MouseEvent-button','MouseEvent.button')}} | {{Spec2('DOM3 Events')}} | Compared to {{SpecName('DOM2 Events')}}, the return value can be negative. |
| {{SpecName('DOM2 Events','#Events-MouseEvent','MouseEvent.button')}} | {{Spec2('DOM2 Events')}} | Initial definition. |
{{Compat("api.MouseEvent.button")}}