JavaScript面试考点之鼠标事件

作者: 团子哒哒 | 来源:发表于2021-08-16 16:19 被阅读0次

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)常见的键位和码值

相关文章

  • JavaScript面试考点之鼠标事件

    1、鼠标事件 鼠标点击事件包括 4 个:click(单击)、dblclick(双击)、mousedown(按下)和...

  • JavaScript ☞ day3

    JavaScript基础学习笔记之JavaScript进阶 焦点事件 鼠标事件-单击与双击 鼠标事件-mouseo...

  • JavaScript事件之鼠标事件

    1. 鼠标事件 在DOM3级事件中定义了9个鼠标事件: click:在用户单击主鼠标按钮(一般是左边的按钮)或按下...

  • jQuery基础(三)—事件篇-----鼠标事件

    jQuery鼠标事件之click与dbclick事件jQuery鼠标事件之mouseover与mouseout事件...

  • JavaScript面试考点之事件代理

    事件代理(Event Delegation),又称之为事件委托。是JavaScript中常用绑定事件的常用技巧。顾...

  • JavaScript面试考点之事件循环

    1、Javascript中的事件循环机制 首先,因为JavaScript是一门单线程的语言。意味着着同一时间内只能...

  • 收藏

    面试题汇总 春招季如何横扫 Javascript 面试核心考点(基础版)?[https://segmentfaul...

  • JavaScript面试考点之HTTP

    1、HTTP 的请求方法 1)GET: 通常用来获取资源。 2)POST: 提交数据,即上传数据。 3)PUT: ...

  • JavaScript面试考点之Websocket

    WebSocket 是 HTML5 开始提供的一种在单个 TCP 连接上进行全双工通讯的协议。 传统的HTTP协议...

  • JavaScript事件

    事件是可以被 JavaScript 侦测到的行为。 事件类型 鼠标事件 键盘事件 其他事件[https://www...

网友评论

    本文标题:JavaScript面试考点之鼠标事件

    本文链接:https://www.haomeiwen.com/subject/twqrbltx.html