zoukankan      html  css  js  c++  java
  • 事件的冒泡行为和默认行为

    <div style="height:200px;200px;background:#ccc;">
    <input type='button' value='按钮'>

    </div>

    // 测试冒泡事件(重叠的这些元素都绑定了同一个事件) 顺序 从小往大

    /* $('input').click(function(){

    alert('input');
    });
    */

    //可以调用事件对像行为e.stopPropagation()来阻止冒泡行为
    $('input').click(function(e){

    alert('input');
    e.stopPropagation();
    });
    $('div').click(function(){

    alert('div');
    });
    //注意 document不需要到引号
    $(document).click(function(){

    alert('document');
    });

    注意:当我们点击文档的时候,只触发文档事件;当我们点击 div 层时,触发了 div 和
    文档两个;当我们点击按钮时,触发了按钮、div 和文档。触发的顺序是从小范围到大范围。
    这就是所谓的冒泡现象,一层一层往上。
    jQuery 提供了一个事件对象的方法:event.stopPropagation();这个方法设置到需要触发
    的事件上时,所有上层的冒泡行为都将被取消。

    网页中的元素,在操作的时候会有自己的默认行为。比如:右击文本框输入区域,会弹
    出系统菜单、点击超链接会跳转到指定页面、点击提交按钮会提交数据。
    $('a').click(function (e) {
    e.preventDefault();
    });
    //禁止提交表单跳转
    $('form').submit(function (e) {
    e.preventDefault();
    });
    注意:如果想让上面的超链接同时阻止默认行为且禁止冒泡行为,可以把两个方法同时
    写上:event.stopPropagation()和 event.preventDefault()。这两个方法如果需要同时启用的时候,
    还有一种简写方案代替,就是直接 return false。
    $('a').click(function (e) {
    return false;
    });

  • 相关阅读:
    【luogu】 P1433 吃奶酪
    【noip 2016】 组合数问题(problem)
    【清北学堂】 死亡(death)
    【noip 2004】 合并果子
    微信小程序:每个邮箱仅能申请一个小程序
    Babel-polyfill 的作用
    react.js中模拟事件总线,子组件调用父组件时,发挥作用
    多行文本溢出显示省略号(…) text-overflow: ellipsis ------------- webkit-line-clamp 多行文字溢出...
    es6-class
    ES6--promise
  • 原文地址:https://www.cnblogs.com/keyi/p/5909543.html
Copyright © 2011-2022 走看看