js火狐以及ie處理鼠標進入與離開事件

在IE下解決問題很簡單,用onMouseEnter、onMouseLeave來代 替onMouseOver、onMouseOut就行了,他們的作用基本相同,前者不會發生冒泡。但是firefox下沒有這兩個事件,如果用 jQuery的event事件,只要bind mouseleave和mouseenter即可。如果是純js實現,只能這麼做:

通過判斷觸發onMouseOut事件後鼠標到達的元素是不是包含在父元素(信息欄Div)內,如果是就表示鼠標還在信息欄上,則不隱藏,如果否就表示鼠標真的移出了信息欄,那麼信息欄隱藏,思路有了,那麼就一步步來解決問題
首先來獲取觸發onMouseOut事件的元素,IE下event的屬性toElement來獲得,在firefox下變成了relatedTarget(很是折騰!)
IE:event.toElement    Firefox:event.relatedTarget(注意Firefox下event須要調用函數時傳入)

接下來就是判斷獲取的元素是否是子元素,IE下通過元素的contains(Element)方法可以判斷,同樣的firefox下沒有這個方法!!,不過可以給firefox下的元素定義contains()方法來解決問題,代碼如下:

if(typeof(HTMLElement)!="undefined")    //給firefox定義contains()方法,ie下不起作用
{   
      HTMLElement.prototype.contains=function(obj)   
      {   
          while(obj!=null&&typeof(obj.tagName)!="undefind"){ //通過循環對比來判斷是不是obj的父元素
       if(obj==this) return true;   
       obj=obj.parentNode;
     }   
          return false;   
      };   
}  

獲取和判斷搞定後,我們就可以通過判斷IE和Firefox來針對處理了,通過navigator.userAgent來判斷瀏覽器:
   if(navigator.userAgent.indexOf("MSIE")>0) { 
        return "MSIE"; 
   } 
   if(navigator.userAgent.indexOf("Firefox")>0){ 
        return "Firefox"; 
   }
 
到此爲止所有要解決的問題都得到了解決,當觸發onMouseOut事件時我們針對不同的瀏覽器先獲取鼠標到達的元素,然後通過判斷該元素是否在信息欄(div)內,如果元素是子元素,那麼不執行onMouseOut事件,反之則執行事件,隱藏信息欄,完成後的代碼如下:
function hideMsgBox(theEvent){ //theEvent用來傳入事件,Firefox的方式
        if (theEvent){
               var browser=navigator.userAgent;   //取得瀏覽器屬性
               if (browser.indexOf("Firefox")>0){ //如果是Firefox
                    if (document.getElementById('MsgBox').contains(theEvent.relatedTarget)) { //如果是子元素
                        return;   //結束函式
                        } 
                } 
                  if (browser.indexOf("MSIE")>0){ //如果是IE
                          if (document.getElementById('MsgBox').contains(event.toElement)) { //如果是子元素
                                return; //結束函式
                           }
                 }
             }
            /*要執行的操作*/
}

在信息欄(Div)上設置onMouseOut=hideMsgBox(event)來調用,解決冒泡問題。
通過設置
window.event.cancelBubble = true (IE) event.stopPropagation() event.preventDefault() 
(Firefox)
也可以解決問題,但是需要遍歷所有子元素,影響效率,所以還是在觸發onMouseOut事件時再進行上述判斷分別處理比較合適。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章