1. setCapture 簡介
setCapture可以將鼠標事件鎖定在指定的元素上,當元素捕獲了鼠標事件後,該事件只能作用在當前元素上。
以下情況會導致事件鎖定失敗:
setCapture只可以作用於以下事件:
setCapture不可作用於鍵盤等其它事件,只能作用於鼠標事件。主要用於: onmouseover 與 onmouseout 事件。
* setCapture該法是IE浏覽器專有。
2. setCapture 使用格式
setCapture 有一個布爾值參數,用於設置是否捕獲其子元素的鼠標事件。
示例: 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>
然後第二次點擊頁面後就會發現鎖定自動取消。