setCapture、releasCapture 浅析
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 <script> 2 var oBox = document.getElementById('infor'), 3 oBtn = document.getElementsByTagName('button')[0]; 4 5 oBtn.onmousedown=function(){ 6 this.setCapture(true); 7 } 8 oBtn.onmouseover = function(){ 9 oBox.innerHTML+='onmouseover | '; 10 } 11 oBtn.onmouseout = function(){ 12 oBox.innerHTML+='onmouseout | '; 13 } 14 oBtn.onmouseup = function(){ 15 oBox.innerHTML+='onmouseup | '; 16 } 17 18 </script>
4. setCapture 总结
setCapture()用于事件的锁定,对应的还有一个解锁事件方法 releaseCapture()方法,releaseCapture()可以为指定的元素解除事件锁定。它们俩必须成对使用。
setCapture()方法主要用于高级的拖动技术,这是因为在IE下,当我们在要拖动的元素上,在按下鼠标按钮然后拖动时,当拖动过快,或者是超出浏览器的文档窗口时,拖动对象身上的onmousedown就会失效。在Chrome我们可以为doucment绑定onmouseout来判断是否发生这样的情况,但是IE下面却行不通,所以最好的解决办法就时为要拖动的元素对象锁定鼠标事件,在拖动后在解除事件锁定。
具体使用案例:http://www.cnblogs.com/HCJJ/p/5834559.html
另外在Firefox中有相似的功能,它们分别是:
· captureEvents(Event.eventType)
· releaseEvents(Event.eventType)
最后在学习的过程中我对setCapture还存在的几个疑问,希望以后能得到高手的指点:
1. 为什么为button元素锁定事件后,没有在button元素上移动,但是还会触发onmouseover与onmouseout事件。
[ 具体代码见上面的DEMO ]
2.在onclick事件中,没法永久将鼠标事件锁定在指定元素上。
1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title>setCapture - Simple - Demo</title> 6 </head> 7 <body> 8 <button>click</button> 9 </body> 10 </html> 11 <script> 12 var oBtn = document.getElementsByTagName('button')[0]; 13 oBtn.onclick=function(){ 14 this.setCapture(); 15 } 16 </script>
然后第二次点击页面后就会发现锁定自动取消。
参考资料:
https://developer.mozilla.org/zh-CN/docs/Web/API/element/setCapture
http://www.cnblogs.com/lln7777/archive/2012/03/20/2408148.html