zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    博客园转载别人的文章的方法
    CSS属性:定位属性(图文详解)
    深入学习css伪类和伪元素及其用法
    CSS3:RGBA的使用方法
    display和visibility,(height: 0; overflow: hidden;)区别
    css居中div的几种常用方法
    高性能RTMP、RTSP、HLS(m3u8)、HTTPFLV流媒体服务器EasyNVR、EasyDSS、EasyGBS系列产品版本信息中获取的ip是否可以更改?
    EasyDSS高性能RTMP、HLS(m3u8)、HTTPFLV流媒体服务器问题之选定时间段录像进行观看会出现“视频播放等待”字样的问题解析
    RTSP、RTMP、HLS、HTTPFLV,Easy系列的流媒体服务核心产品EasyDSS_kernel在使用hls拉流提示跨域问题是什么原因造成的?
    EasyDSS高性能RTMP、HLS(m3u8)、HTTPFLV、RTSP流媒体服务器解决方案之EasyDSS版本免费更新的方法
  • 原文地址:https://www.cnblogs.com/HCJJ/p/5904515.html
Copyright © 2011-2022 走看看