zoukankan      html  css  js  c++  java
  • 阻止冒泡,和取消默认事件

    js冒泡和捕获是事件的两种行为,使用event.stopPropagation()起到阻止捕获和冒泡阶段中当前事件的进一步传播。使用event.preventDefault()可以取消默认事件

    防止冒泡和捕获

    标准: e.stopPropagation(),IE: e.cancelBubble = true
    stopPropagation也是事件对象(Event)的一个方法,作用是阻止目标元素的冒泡事件,但是会不阻止默认行为

    <div id='div' onclick='alert("div");'>
    <ul onclick='alert("ul");'>
    <li onclick='alert("li");'>test</li>
    </ul>
    </div>
    

    单击test时,会依次触发alert(“li”),alert(“ul”),alert(“div”),这就是事件冒泡

    阻止冒泡:

    window.event? window.event.cancelBubble = true : e.stopPropagation();

    取消默认事件:

    标准: e.preventDefault(),IE: e.returnValue = false;
    preventDefault它是事件对象(Event)的一个方法,作用是取消一个目标元素的默认行为;
    有默认行为的元素有:链接a,提交按钮input type=”submit”等。
    当Event 对象的 cancelable为false时,表示没有默认行为,这时即使有默认行为,调用preventDefault也是不会起作用的。

    //假定有链接<a href="http://caibaojian.com/" id="testA" >caibaojian.com</a>
    var a = document.getElementById("testA");
    a.onclick =function(e){
    if(e.preventDefault){
    e.preventDefault();
    }else{
    window.event.returnValue == false;
    }
    }
    
    return false

    javascript的return false只会阻止默认行为,而是用jQuery的话则既阻止默认行为又防止对象冒泡。

    //原生js,只会阻止默认行为,不会停止冒泡
    <div id='div'  onclick='alert("div");'>
    <ul  onclick='alert("ul");'>
    <li id='ul-a' onclick='alert("li");'><a href="http://caibaojian.com/"id="testB">caibaojian.com</a></li>
    </ul>
    </div>
    var a = document.getElementById("testB");
    a.onclick = function(){
    return false;
    };
    
    //使用jQuery,既阻止默认行为又停止冒泡
    <div id='div'  onclick='alert("div");'>
    <ul  onclick='alert("ul");'>
    <li id='ul-a' onclick='alert("li");'><a href="http://caibaojian.com/"id="testC">caibaojian.com</a></li>
    </ul>
    </div>
    $("#testC").on('click',function(){
    return false;
    });
    

    总结使用方法

    当需要停止冒泡行为时,可以使用

    function stopBubble(e) { 
    //如果提供了事件对象,则这是一个非IE浏览器 
    if ( e && e.stopPropagation ) 
        //因此它支持W3C的stopPropagation()方法 
        e.stopPropagation(); 
    else 
        //否则,我们需要使用IE的方式来取消事件冒泡 
        window.event.cancelBubble = true; 
    }
    

    当需要阻止默认行为时,可以使用

    //阻止浏览器的默认行为 
    function stopDefault( e ) { 
        //阻止默认浏览器动作(W3C) 
        if ( e && e.preventDefault ) 
            e.preventDefault(); 
        //IE中阻止函数器默认动作的方式 
        else 
            window.event.returnValue = false; 
        return false; 
    }
    

    事件注意点
    event代表事件的状态,例如触发event对象的元素、鼠标的位置及状态、按下的键等等;
    event对象只在事件发生的过程中才有效。
    firefox里的event跟IE里的不同,IE里的是全局变量,随时可用;firefox里的要用参数引导才能用,是运行时的临时变量。
    在IE/Opera中是window.event,在Firefox中是event;而事件的对象,在IE中是window.event.srcElement,在Firefox中是event.target,Opera中两者都可用。

    下面两句效果相同:

    function a(e){
    var e = (e) ? e : ((window.event) ? window.event : null); 
    var e = e || window.event; // firefox下window.event为null, IE下event为null
    }
    

    链接:http://caibaojian.com/javascript-stoppropagation-preventdefault.html

  • 相关阅读:
    PDF文件中的Form保存问题
    Understanding IP Fragmentation
    tcp ip guide IPsec IKE
    Windows安全事件日志中的事件编号与描述
    Cisco PIX fix up and Juniper firewall FTP ALG
    很好的IPSec介绍,详细解释了IKE协商的2个阶段的作用
    virtualbox 下运行Ubuntu 8.10的分辨率和guest additions的问题。
    Fixing the ‘Do you want to display nonsecure items’ message
    windows xp 开始菜单里面所有项目右键不起作用。
    HP backup and recovery manager
  • 原文地址:https://www.cnblogs.com/cherishnow/p/10948000.html
Copyright © 2011-2022 走看看