国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

JavaScript和JQuery的鼠標mouse事件冒泡處理

2019-11-20 12:13:00
字體:
來源:轉載
供稿:網友

簡單的鼠標移動事件:

進入

復制代碼 代碼如下:

mouseenter:不冒泡
mouseover: 冒泡

不論鼠標指針穿過被選元素或其子元素,都會觸發 mouseover 事件
只有在鼠標指針穿過被選元素時,才會觸發 mouseenter 事件

移出

復制代碼 代碼如下:

mouseleave: 不冒泡
mouseout:冒泡

不論鼠標指針離開被選元素還是任何子元素,都會觸發 mouseout 事件
只有在鼠標指針離開被選元素時,才會觸發 mouseleave 事件

我們通過一個案例觀察下問題:

給一個嵌套的層級綁定mouseout事件,會發現mouseout事件與想象的不一樣

復制代碼 代碼如下:

<!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;">內部子元素</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>

我們發現一個問題mouseout事件:

1.無法阻止冒泡
2.在內部的子元素上也會觸發

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

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

jQuery的處理也是如出一轍

復制代碼 代碼如下:

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;
            }
        };
    });

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 资阳市| 丰顺县| 宣化县| 靖边县| 博湖县| 桑植县| 天全县| 霍邱县| 原阳县| 鹤庆县| 阿克| 铁岭县| 罗田县| 汝州市| 青冈县| 寿阳县| 吴忠市| 建水县| 色达县| 虹口区| 朝阳区| 惠东县| 阿城市| 临桂县| 望江县| 绵竹市| 阿尔山市| 万源市| 綦江县| 永兴县| 鹤庆县| 松潘县| 光山县| 且末县| 当阳市| 廊坊市| 淮南市| 平果县| 孟州市| 尚志市| 本溪|