* setCapture该法是IE浏览器专有
1. setCapture 简介
setCapture可以将鼠标事件锁定在指定的元素上,当元素捕获了鼠标事件后,该事件只能感化在当前元素上。
以下情况会导致事件锁定掉败:
当窗口掉去焦点时,锁定的事件,自动就会打消。
alert也会导致事件的锁定打消。解决步伐是在alert之后再次锁定。
鼠标右键也会导致事件解锁。
setCapture只可以感化于以下事件:
onclick
ondblclick
onmousedown
onmouseup
onmou搜索引擎优化ver
onmou搜索引擎优化ut
setCapture不成感化于键盘等其它事件,只能感化于鼠标事件。主要用于: onmou搜索引擎优化ver 与 onmou搜索引擎优化ut 事件。
* setCapture该法是IE浏览器专有。
2. setCapture 使用格局
setCapture 有一个布尔值参数,用于设置是否捕获其子元素的鼠标事件。
当参数是ture时 ,当前元素会捕获其内的所有子元素的鼠标事件,即指定元素内的子元素不会触发鼠标事件,也就是当前元素内的子元素与当前元素外的元素一致。
当参数为false时,当前元素不会捕获该其内的所有子元素的鼠标事件。容器内的东西能够正常地触发事件和打消冒泡。
示例: currElement.setCapture(boolean)
3. setCapture - Simple - Demo
<script> var oBox = document.getElementById(‘infor‘), oBtn = document.getElementsByTagName(‘button‘)[0]; oBtn.onmousedown=function(){ this.setCapture(true); } oBtn.onmou搜索引擎优化ver = function(){ oBox.innerHTML+=‘onmou搜索引擎优化ver | ‘; } oBtn.onmou搜索引擎优化ut = function(){ oBox.innerHTML+=‘onmou搜索引擎优化ut | ‘; } oBtn.onmouseup = function(){ oBox.innerHTML+=‘onmouseup | ‘; } </script>
4. setCapture 总结
setCapture()用于事件的锁定,对应的还有一个解锁事件要领 releaseCapture()要领,releaseCapture()可以为指定的元素解除事件锁定。它们俩必需成对使用。
setCapture()要领主要用于高级的拖动技术,这是因为在IE下,当我们在要拖动的元素上,在按下鼠标按钮然后拖动时,当拖动过快,或者是超过浏览器的文档窗口时,拖动东西身上的onmousedown就会掉效。在Chrome我们可以为doucment绑定onmou搜索引擎优化ut来判断是否产生这样的情况,但是IE下面却行欠亨,所以最好的解决步伐就时为要拖动的元素东西锁定鼠标事件,在拖动后在解除事件锁定。
具体使用案例://www.jb51.net/article/93446.htm
此外在Firefox中有相似的成果,,它们分袂是:
· captureEvents(Event.eventType)
· releaseEvents(Event.eventType)
最后在学习的过程中我对setCapture还存在的几个疑问,但愿以后能得到妙手的指点:
1. 为什么为button元素锁定事件后,没有在button元素上移动,但是还会触发onmou搜索引擎优化ver与onmou搜索引擎优化ut事件。
[ 具体代码见上面的DEMO ]
2.在onclick事件中,没法永久将鼠标事件锁定在指定元素上。
<!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>
然后第二次点击页面后就会发明锁定自动打消。
温馨提示: 本文由Jm博客推荐,转载请保留链接: https://www.jmwww.net/file/web/32700.html
- 上一篇:格子宽度就是行宽除以单行格子个数
- 下一篇:牢固下CSS,CSS太庞大~