欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript和JQuery的鼠標(biāo)mouse事件冒泡處理

 更新時(shí)間:2015年06月19日 09:12:59   投稿:junjie  
這篇文章主要介紹了JavaScript和JQuery的鼠標(biāo)mouse事件冒泡處理,本文總結(jié)出了mouse事件的一些定論,并分別給出了JavaScript和JQuery測(cè)試代碼,需要的朋友可以參考下

簡(jiǎn)單的鼠標(biāo)移動(dòng)事件:

進(jìn)入

復(fù)制代碼 代碼如下:

mouseenter:不冒泡
mouseover: 冒泡

不論鼠標(biāo)指針穿過(guò)被選元素或其子元素,都會(huì)觸發(fā) mouseover 事件
只有在鼠標(biāo)指針穿過(guò)被選元素時(shí),才會(huì)觸發(fā) mouseenter 事件

移出

復(fù)制代碼 代碼如下:

mouseleave: 不冒泡
mouseout:冒泡

不論鼠標(biāo)指針離開(kāi)被選元素還是任何子元素,都會(huì)觸發(fā) mouseout 事件
只有在鼠標(biāo)指針離開(kāi)被選元素時(shí),才會(huì)觸發(fā) mouseleave 事件

我們通過(guò)一個(gè)案例觀察下問(wèn)題:

給一個(gè)嵌套的層級(jí)綁定mouseout事件,會(huì)發(fā)現(xiàn)mouseout事件與想象的不一樣

復(fù)制代碼 代碼如下:

<!DOCTYPE html><div class="out overout" style="width:40%;height:120px; margin:0 15px;background-color:#D6EDFC;float:left;" data-mce-style="width: 40%; height: 120px; margin: 0 15px; background-color: #d6edfc; float: left;"><p style="border:1px solid red" data-mce-style="border: 1px solid red;">外部子元素</p><div class="in overout" style="width:60%;background-color:#FFCC00;margin:10px auto;" data-mce-style="width: 60%; background-color: #ffcc00; margin: 10px auto;"><p style="border:1px solid red" data-mce-style="border: 1px solid red;">內(nèi)部子元素</p><p id="inshow">0</p>
    </div><p id="outshow">0</p>
</div><script type="text/javascript">

    var i = 0;
    var k = 0;

    document.querySelectorAll('.out')[0].addEventListener('mouseout',function(e){
        document.querySelectorAll("#inshow")[0].textContent = (++i)
       e.stopPropagation();
    },false)

   document.querySelectorAll('.in')[0].addEventListener('mouseout',function(){
       document.querySelectorAll("#outshow")[0].textContent = (++k)
    },false)

</script>

我們發(fā)現(xiàn)一個(gè)問(wèn)題mouseout事件:

1.無(wú)法阻止冒泡
2.在內(nèi)部的子元素上也會(huì)觸發(fā)

同樣的問(wèn)題還有mouseover事件,那么在stopPropagation方法失效的情況下我們要如何停止冒泡呢?

1.為了阻止mouseover和mouseout的反復(fù)觸發(fā),這里要用到event對(duì)象的一個(gè)屬性relatedTarget,這個(gè)屬性就是用來(lái)判斷 mouseover和mouseout事件目標(biāo)節(jié)點(diǎn)的相關(guān)節(jié)點(diǎn)的屬性。簡(jiǎn)單的來(lái)說(shuō)就是當(dāng)觸發(fā)mouseover事件時(shí),relatedTarget屬性代表的就是鼠標(biāo)剛剛離開(kāi)的那個(gè)節(jié)點(diǎn),當(dāng)觸發(fā)mouseout事件時(shí)它代表的是鼠標(biāo)移向的那個(gè)對(duì)象。由于MSIE不支持這個(gè)屬性,不過(guò)它有代替的屬性,分別是 fromElement和toElement。
2.有了這個(gè)屬性,我們就能夠清楚的知道我們的鼠標(biāo)是從哪個(gè)對(duì)象移過(guò)來(lái),又是要移動(dòng)到哪里去了。這樣我們就能夠通過(guò)判斷這個(gè)相關(guān)聯(lián)的對(duì)象是否在我們要觸發(fā)事件的對(duì)象的內(nèi)部,或者是不是就是這個(gè)對(duì)象本身。通過(guò)這個(gè)判斷我們就能夠合理的選擇是否真的要觸發(fā)事件。
3.這里我們還用到了一個(gè)用于檢查一個(gè)對(duì)象是否包含在另外一個(gè)對(duì)象中的方法,contains方法。MSIE和FireFox分別提供了檢查的方法,這里封裝了一個(gè)函數(shù)。

jQuery的處理也是如出一轍

復(fù)制代碼 代碼如下:

jQuery.each({
        mouseenter: "mouseover",
        mouseleave: "mouseout",
        pointerenter: "pointerover",
        pointerleave: "pointerout"
    }, function(orig, fix) {
        jQuery.event.special[orig] = {
            delegateType: fix,
            bindType: fix,

            handle: function(event) {
                var ret,
                    target = this,
                    related = event.relatedTarget,
                    handleObj = event.handleObj;

                // For mousenter/leave call the handler if related is outside the target.
                // NB: No relatedTarget if the mouse left/entered the browser window
                if (!related || (related !== target && !jQuery.contains(target, related))) {
                    event.type = handleObj.origType;
                    ret = handleObj.handler.apply(this, arguments);
                    event.type = fix;
                }
                return ret;
            }
        };
    });

相關(guān)文章

  • JavaScript轉(zhuǎn)換與解析JSON方法實(shí)例詳解

    JavaScript轉(zhuǎn)換與解析JSON方法實(shí)例詳解

    這篇文章主要介紹了JavaScript轉(zhuǎn)換與解析JSON方法,實(shí)例分析了JavaScript解析json的技巧,并附帶分析了jQuery解析與轉(zhuǎn)換json的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-11-11
  • JavaScript中Object基礎(chǔ)內(nèi)部方法圖

    JavaScript中Object基礎(chǔ)內(nèi)部方法圖

    本篇文章通過(guò)一張?jiān)敿?xì)的JavaScript中Object基礎(chǔ)內(nèi)部方法圖介紹了其基本用法,需要的朋友參考下。
    2018-02-02
  • Angular組件拿不到@Input輸入屬性問(wèn)題探究解決方法

    Angular組件拿不到@Input輸入屬性問(wèn)題探究解決方法

    最近在工作中實(shí)現(xiàn)一個(gè)feature的時(shí)候,碰到一個(gè)小問(wèn)題:Angular組件拿不到@Input輸入屬性的問(wèn)題,盡管對(duì)這些問(wèn)題都比較了解,但是找問(wèn)題是需要一個(gè)過(guò)程的,所以還是把這個(gè)問(wèn)題總結(jié)記錄了下
    2023-01-01
  • 詳細(xì)解析let和const命令

    詳細(xì)解析let和const命令

    這篇文章主要介紹了詳細(xì)解析let和const命令,let和const是es6中新增的命令,一般let用來(lái)聲明變量而const則用來(lái)聲明常量,更多相關(guān)內(nèi)容感興趣的小伙伴可以參考一下
    2022-06-06
  • JsonProperty 的使用方法詳解

    JsonProperty 的使用方法詳解

    這篇文章主要介紹了JsonProperty 的使用方法詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-10-10
  • 詳解Webwork中Action 調(diào)用的方法

    詳解Webwork中Action 調(diào)用的方法

    這篇文章主要介紹了詳解Webwork中Action 調(diào)用的方法的相關(guān)資料,需要的朋友可以參考下
    2016-02-02
  • js實(shí)現(xiàn)tab欄切換制作

    js實(shí)現(xiàn)tab欄切換制作

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)tab欄切換制作,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • JavaScript實(shí)現(xiàn)的聯(lián)動(dòng)菜單特效示例

    JavaScript實(shí)現(xiàn)的聯(lián)動(dòng)菜單特效示例

    這篇文章主要介紹了JavaScript實(shí)現(xiàn)的聯(lián)動(dòng)菜單特效,涉及javascript事件響應(yīng)及頁(yè)面元素屬性動(dòng)態(tài)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2019-07-07
  • javascript 24點(diǎn)游戲代碼

    javascript 24點(diǎn)游戲代碼

    非常不錯(cuò)的技術(shù)24點(diǎn)的游戲代碼,他的算法值得學(xué)習(xí),希望喜歡游戲的朋友,可以來(lái)看看
    2008-06-06
  • JavaScript變量提升和嚴(yán)格模式實(shí)例分析

    JavaScript變量提升和嚴(yán)格模式實(shí)例分析

    這篇文章主要介紹了JavaScript變量提升和嚴(yán)格模式,結(jié)合實(shí)例形式分析了javascript變量提升和嚴(yán)格模式的原理及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下
    2019-01-01

最新評(píng)論