DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> HTML中setCapture、releaseCapture 使用方法淺析
HTML中setCapture、releaseCapture 使用方法淺析
編輯:關於JavaScript     

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下面卻行不通,所以最好的解決辦法就時為要拖動的元素對象鎖定鼠標事件,在拖動後在解除事件鎖定。

具體使用案例:http://www.jb51.net/article/93446.htm

另外在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>

  然後第二次點擊頁面後就會發現鎖定自動取消。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved