HTML中setCapture、releaseCapture 使用方法浅析
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
<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狼蚁网站SEO优化却行不通,所以最好的解决办法就时为要拖动的元素对象锁定鼠标事件,在拖动后在解除事件锁定。
具体使用案例
在Firefox中有相似的功能,它们分别是
· captureEvents(Event.eventType)
· releaseEvents(Event.eventType)
在学习的过程中我对setCapture还存在的几个疑问,希望以后能得到高手的指点
1. 为什么为button元素锁定事件后,没有在button元素上移动,还会触发onmouseover与onmouseout事件。
[ 具体代码见上面的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>
然后第二次点击页面后就会发现锁定自动取消。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程