javascript鼠标事件总结
以下是为大家整理的javascript鼠标事件总结的相关范文,本文关键词为javascript,鼠标,事件,总结,常见,以下,8个,m,您可以从右上方搜索框检索更多相关文章,如果您觉得有用,请继续关注我们并推荐给您的好友,您可以在教育文库中查看更多范文。
常见的有以下8个:
mousedown:鼠标的键钮被按下。mouseup:鼠标的键钮被释放弹起。click:单击鼠标的键钮。
dblclick:鼠标的键钮被按下。contextmenu:弹出右键菜单。
mouseover:鼠标移到目标的上方。mouseout:鼠标移出目标的上方。mousemove:鼠标在目标的上方移动。
mousedown事件与mouseup事件可以说click事件在时间上的细分,顺序是mousedown=>mouseup=>click。因此一个点击事件,通常会激发几个鼠标事件。
请在这里点击,测试一个点击到底捆绑了多少种鼠标事件?!
[ctrl+A全选提示:你可先修改部分代码,再按运行]
有了它们,我们可以做许多事,但对于高层次的应用(如游戏)是显然不够的,于是鼠标事件的点击事件又根据究竟是点左键还是右键进行细分。在Dom2.0中,w3c对鼠标事件作了现范,鼠标事件被解析为mouseevent(我们可以用e.constructor==mouseevent来判断其是否为鼠标事件,是左键点击还是右键点击由它的一个叫button 的属性判定。以下就是w3c的标准现范:0:按下左键
1:按下中键(如果有的话)2:按下右键
当然微软是不会妥协的,因为e.button本来就是微软最先实现的,网景用的是e.which,但相对而言,微软的复杂多了。0:没有键被按下1:按下左键2:按下右键
3:左键与右键同时被按下4:按下中键
5:左键与中键同时被按下6:中键与右键同时被按下7:三个键同时被按下更详细的情况见下表。
ge:gecko;sA:safari;op:opera;ns:netscape
Iens4ge≥1.0sA3
op≥8.0ge0.9op    e.button左键1undefined011中键4undefined123右键2undefined232
e.which左键undefined1111中键undefined2223右键undefined3332
为此我们可以使用以下函数来绑定左右键。
mousemove是什么键复制代码代码如下:
varmouseevent=function(){vararg=arguments[0],el=arg.el||document,
leftfn=arg.left||function(){},rightfn=arg.right||function(){},middlefn=arg. middle||function(){},buttons={};
switch(e.button){
case1:buttons.left=true;break;case2:buttons.right=true;break;case4:butt ons.middle=true;break;}
}else{
switch(e.which){
case1:buttons.left=true;break;case2:buttons.middle=true;break;case3:b
uttons.right=true;break;}
}
if(buttons.left){leftfn();
}elseif(buttons.middle){middlefn();
}elseif(buttons.right){rightfn();}
buttons={\\\};}}
它接受一个哈希参数,都是可选项。哈希的el为要绑定鼠标事件的元素,left为点击左键激发的事件,其他两个类推。用法如下:复制代码代码如下:
lementbyId(\
lementbyId(\varleft=function(){
ex.innerhTmL=\左键被按下\}
varright=function(){
ex.innerhTmL=\右键被按下\}
mouseevent({el:el,left:left,middle:null,right:right});
请在这里点击,测试左中右鼠标键绑定函数
load!='function'){load=fn;
}else{
varmouseevent=function(){vararg=arguments[0],el=arg.el||document,
leftfn=arg.left||function(){},rightfn=arg.right||function(){},middlefn=arg. middle||function(){},buttons={};
switch(e.button){
case1:buttons.left=true;break;case2:buttons.right=true;break;case4:butt ons.middle=true;break;}
}else{
switch(e.which){
case1:buttons.left=true;break;case2:buttons.middle=true;break;case3:b uttons.right=true;break;}}
if(buttons.left){leftfn();
}elseif(buttons.middle){middlefn();
}elseif(buttons.right){rightfn();}
buttons={\\\};}}
以下是为大家整理的javascript鼠标事件总结(2)的相关范文,本文关键词为javascript,鼠标,事件,总结,常见,以下,8个,m,您可以从右上方搜索框检索更多相关文章,如果您觉得有用,请继续关注我们并推荐给您的好友,您可以在教育文库中查看更多范文。
最后,小编希望文章对您有所帮助,如果有不周到的地方请多谅解,更多相关的文章正在创作中,希望您定期关注。谢谢支持!

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。