• js 事件流理解 && 阻止事件冒泡和默认行为


     

     

    第一:事件流:在页面接受事件的顺序。分两个阶段 1事件捕获阶段 2目标阶段 3事件冒泡阶段

        1事件捕获阶段:是从上而下查找如 document->html->body->div

        2目标阶段

        3事件冒泡阶段:是从下而上找(与上相反)

      addEventListenter有三个参数(事件,回调函数,boolean[false:冒泡--默认,true:捕获])

     

        父元素

       

          子元素

       

     

      事件捕获情况:

      点击子元素div情况下:

      let child = document.querySelector('.child')

      child.addEventListener('click',function(){

        alert('我是子元素')

      },true)//true捕获 从上而下 事件先打印父元素在打印子元素。

      let parent = document.querySelector('.parent')

      parent.addEventListener('click',function(){

        alert('我是父元素')

      },true)

      事件冒泡情况

      点击子元素div情况下:

       let child = document.querySelector('.child')

      child.addEventListener('click',function(){

        alert('我是子元素')

      },false)//false捕获 从下而上 事件都先打印子元素在打印父元素。

      let parent = document.querySelector('.parent')

      parent.addEventListener('click',function(){

        alert('我是父元素')

      },false)

    第二:阻止事件冒泡和默认行为

    div class="parent">

        父元素

       

          子元素

       

     

      1 阻止默认行为如下:

      阻止a标签跳转到www.jd.com

      var aa = document.querySelector('a')

      aa.addEventListener('click',function(e){

        //1 种

        e.preventDefault();

        //2 种 兼容性问题 老版本ie

       // e.returnValue = false;

        //3 种

        //return false;

      })

      2 阻止事件冒泡

        let child = document.querySelector('.child')

        child.addEventListener('click',function(e){

          alert('我是子元素')

          e.stopPropagation() //主要这句话

          //e.cancelBubble = true //兼容性老版本ie 取消冒泡

        },false)//冒泡行为默认是false 可以不写 false

      let parent = document.querySelector('.parent')

      parent.addEventListener('click',function(){

        alert('我是父元素')

      },false)

  • 相关阅读:
    百度等8家企业首批上线大模型服务;大语言模型微调之道
    IFoerster IsoSDK FoxSDK Crack-2022
    基于uni-app和图鸟UI的云课堂小程序开发实践
    两轮平衡电动车原理简单叙述
    自学的程序员一点竞争力都没有吗?投了5天简历,一个面试通知都没有怎么办?
    【学习笔记66】JavaScript的深浅拷贝
    【TS】函数重载--可选参数--默认参数
    ESP8266-Arduino编程实例-VEML6075紫外线(UV)光传感器驱动
    引理和定理啥区别
    ES6学习笔记
  • 原文地址:https://blog.csdn.net/m0_65730686/article/details/126140161