JavaScript面试考点之鼠标事件

团子哒哒IP属地: 北京
0.487字数 922

1、鼠标事件

鼠标点击事件包括 4 个:click(单击)、dblclick(双击)、mousedown(按下)和 mouseup(松开)。其中 click事件类型比较常用,而 mousedown 和 mouseup 事件类型多用在鼠标拖放、拉伸操作中。当这些事件处理函数的返回值为 false时,会禁止绑定对象的默认行为。

a、click:单击鼠标左键时发生,如果右键也按下则不会发生。当用户的焦点在按钮上并按了 Enter 键时,同样会触发这个事件‘’

b、dblclick:双击鼠标左键时发生,如果右键也按下则不会发生

c、mousedown:单击任意一个鼠标按钮时发生

d、mouseup:松开任意一个鼠标按钮时发生

鼠标经过包括移过和移出两种事件类型。当移动鼠标指针到某个元素上时,将触发 mouseover 事件;而当把鼠标指针移出某个元素时,将触发 mouseout 事件。

a、mouseover:鼠标指针移出某个元素到另一个元素上时发生。

b、mouseout:鼠标指针位于某个元素上且将要移出元素的边界时发生。

用mouseleave/mouseenter代替mouseover/mouseout

1)mouseover与mouseenter

mouseover:不论鼠标指针穿过被选元素或其子元素,都会触发 mouseover 事件。

mouseenter:只有在鼠标指针从元素外穿入被选元素(到元素内)时,才会触发 mouseenter 事件。

2)mouseout与mouseleave

mouseout:不论鼠标指针离开被选元素还是任何子元素,都会触发 mouseout 事件。

mouseleave:只有在鼠标指针从元素内穿出被选元素(到元素外)时,才会触发 mouseleave 事件。

鼠标移动事件mousemove 是一个实时响应的事件,当鼠标指针的位置发生变化时(至少移动一个像素),就会触发 mousemove 事件。

a、mousemove:鼠标在某个元素上时持续发生

当鼠标单击事件发生时,会触发很多事件:mousedown、mouseup、click、dblclick。这些事件响应的顺序如下:mousedown → mouseup → click → mousedown → mouseup → click → dblclick

鼠标定位

鼠标事件实现页面元素拖放操作的设计过程。实现拖放操作设计需要解决以下几个问题。

清楚几个坐标概念:按下鼠标时的指针坐标,移动中当前鼠标指针坐标,松开鼠标时的指针坐标,拖放元素的原始坐标,拖动中的元素坐标。

原理设计:按下鼠标时,获取被拖放元素和鼠标指针的位置,在移动中实时计算鼠标偏移的距离,并利用该偏移距离加上被拖放元素的原坐标位置,获得拖放元素的实时坐标。

拖拽实现

2、键盘实现

keydown:在键盘上按下某个键时触发。如果按住某个键,会不断触发该事件。

keypress:按下某个键盘键并释放时触发。如果按住某个键,会不断触发该事件。该事件处理函数返回 false 时,会取消默认的动作(如输入的键盘字符)。

keyup:释放某个键盘键时触发。该事件仅在松开键盘时触发一次,不是一个持续的响应状态。

1)键盘事件属性

2)常见的键位和码值

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
1人点赞
团子哒哒一点一点往上爬
总资产23共写了12.7W字获得360个赞共122个粉丝

推荐阅读更多精彩内容

  • 鼠标事件在DOM3级事件中定义了9个鼠标事件: click:在用户单击主鼠标按钮(一般是左边的按钮)或按下回车键时...
    浩瀚_null阅读 269评论 0 1
  • DOM3级事件中定义了以下9个鼠标事件: click:在用户单击主鼠标按钮或者按下回车键时触发。意味着onclic...
    陆lmj阅读 1,224评论 0 1
  • 第13章 事件 1. 事件流 事件流描述的是从页面中接收事件的顺序。 (1) 事件冒泡 IE 的事件流叫做事件冒泡...
    yinxmm阅读 969评论 0 17
  • 事件处理程序在应用中是必不可少的,虽然现在很多框架都有自己实现事件处理方法,但是熟知原生才能让我们应对各种各样的需...
    俗三疯阅读 310评论 0 1
  • Web 浏览器中可能发生的事件有很多类型。如前所述,不同的事件类型具有不同的信息,而 DOM3 级事件规定了以下几...
    More_5897阅读 974评论 1 0