obj.setCapture()

本文详细介绍了setCapture方法,一种用于锁定鼠标事件的技术。探讨了其在IE浏览器中的使用方式及应用场景,尤其是在实现高级拖动效果方面的优势。同时,文章对比了Firefox中的类似功能,并通过示例代码展示了如何使用setCapture。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. setCapture 简介

setCapture可以将鼠标事件锁定在指定的元素上,当元素捕获了鼠标事件后,该事件只能作用在当前元素上。

以下情况会导致事件锁定失败:

  • 当窗口失去焦点时,锁定的事件,自动就会取消。
  • alert也会导致事件的锁定取消。解决办法是在alert之后再次锁定。
  • 鼠标右键也会导致事件解锁。

setCapture只可以作用于以下事件:

  • onclick
  • ondblclick
  • onmousedown
  • onmouseup
  • onmouseover
  • onmouseout

 setCapture不可作用于键盘等其它事件,只能作用于鼠标事件。主要用于: onmouseover  与  onmouseout 事件。

* setCapture该法是IE浏览器专有。

2. setCapture 使用格式

setCapture 有一个布尔值参数,用于设置是否捕获其子元素的鼠标事件。

  •   当参数是ture时 ,当前元素会捕获其内的所有子元素的鼠标事件,即指定元素内的子元素不会触发鼠标事件,也就是当前元素内的子元素与当前元素外的元素一致。
  •   当参数为false时,当前元素不会捕获该其内的所有子元素的鼠标事件。容器内的对象能够正常地触发事件和取消冒泡。

示例: currElement.setCapture(boolean) 

3. setCapture - Simple - Demo

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
<script>
  var oBox = document.getElementById( 'infor' ),
   oBtn = document.getElementsByTagName( 'button' )[0];
 
  oBtn.onmousedown= function (){
   this .setCapture( true );
  }
  oBtn.onmouseover = function (){
  oBox.innerHTML+= 'onmouseover | ' ;
  }
  oBtn.onmouseout = function (){
  oBox.innerHTML+= 'onmouseout | ' ;
  }
  oBtn.onmouseup = function (){
  oBox.innerHTML+= 'onmouseup | ' ;
  }
 
</script>

4. setCapture 总结

setCapture()用于事件的锁定,对应的还有一个解锁事件方法 releaseCapture()方法,releaseCapture()可以为指定的元素解除事件锁定。它们俩必须成对使用。

setCapture()方法主要用于高级的拖动技术,这是因为在IE下,当我们在要拖

动的元素上,在按下鼠标按钮然后拖动时,当拖动过快,或者是超出浏览器的文档窗口时,拖动对象身上的onmousedown就会失效。在Chrome我们可以为doucment绑定onmouseout来判断是否发生这样的情况,但是IE下面却行不通,所以最好的解决办法就时为要拖动的元素对象锁定鼠标事件,在拖动后在解除事件锁定。

具体使用案例:http://www.jb51.net/article/93446.htm

另外在Firefox中有相似的功能,它们分别是:

· captureEvents(Event.eventType) 
· releaseEvents(Event.eventType)

最后在学习的过程中我对setCapture还存在的几个疑问,希望以后能得到高手的指点:

  1. 为什么为button元素锁定事件后,没有在button元素上移动,但是还会触发onmouseover与onmouseout事件。

    [ 具体代码见上面的DEMO ]

  2.在onclick事件中,没法永久将鼠标事件锁定在指定元素上。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
<!DOCTYPE html>
<html lang= "en" >
  <head>
  <meta charset= "UTF-8" >
  <title>setCapture - Simple - Demo</title>
  </head>
  <body>
   <button>click</button>
  </body>
</html>
  <script>
  var oBtn = document.getElementsByTagName( 'button' )[0];
  oBtn.onclick= function (){
   this .setCapture();
  }
  </script>

  然后第二次点击页面后就会发现锁定自动取消。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值