源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

HTML中setCapture、releaseCapture 使用方法浅析

  • 时间:2020-01-24 21:52 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:HTML中setCapture、releaseCapture 使用方法浅析
[b]1. setCapture 简介[/b] setCapture可以将鼠标事件锁定在指定的元素上,当元素捕获了鼠标事件后,该事件只能作用在当前元素上。 以下情况会导致事件锁定失败: [list] [*]当窗口失去焦点时,锁定的事件,自动就会取消。[/*] [*]alert也会导致事件的锁定取消。解决办法是在alert之后再次锁定。[/*] [*]鼠标右键也会导致事件解锁。 [/*] [/list] setCapture只可以作用于以下事件: [list] [*]onclick[/*] [*]ondblclick[/*] [*]onmousedown[/*] [*]onmouseup[/*] [*]onmouseover[/*] [*]onmouseout [/*] [/list]  setCapture不可作用于键盘等其它事件,只能作用于鼠标事件。主要用于: onmouseover  与  onmouseout 事件。 * setCapture该法是IE浏览器专有。 [b]2. setCapture 使用格式 [/b] setCapture 有一个布尔值参数,用于设置是否捕获其子元素的鼠标事件。 [list] [*]  当参数是ture时 ,当前元素会捕获其内的所有子元素的鼠标事件,即指定元素内的子元素不会触发鼠标事件,也就是当前元素内的子元素与当前元素外的元素一致。[/*] [*]  当参数为false时,当前元素不会捕获该其内的所有子元素的鼠标事件。容器内的对象能够正常地触发事件和取消冒泡。[/*] [/list] 示例: [code]currElement.setCapture(boolean) [/code] [b]3. setCapture - Simple - Demo[/b]
<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>

[b]4. setCapture 总结[/b] setCapture()用于事件的锁定,对应的还有一个解锁事件方法 releaseCapture()方法,releaseCapture()可以为指定的元素解除事件锁定。它们俩必须成对使用。 setCapture()方法主要用于高级的拖动技术,这是因为在IE下,当我们在要拖动的元素上,在按下鼠标按钮然后拖动时,当拖动过快,或者是超出浏览器的文档窗口时,拖动对象身上的onmousedown就会失效。在Chrome我们可以为doucment绑定onmouseout来判断是否发生这样的情况,但是IE下面却行不通,所以最好的解决办法就时为要拖动的元素对象锁定鼠标事件,在拖动后在解除事件锁定。 具体使用案例:[url=http://www.1sucai.cn/article/93446.htm]http://www.1sucai.cn/article/93446.htm[/url] 另外在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>

  然后第二次点击页面后就会发现锁定自动取消。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部