3.DOM-事件进阶(事件对象、事件委托)

news2025/2/27 20:15:53

环境对象this

环境对象本质上是一个关键字 this
this所在的代码区域不同,代表的含义不同

全局作用域中的this

全局作用域中this代表window对象

局部作用域中的this

在局部作用域中(函数中)this代表window对象
原因是函数调用的时候简写了,函数完整写法window.函数()
在这里插入图片描述

事件局部作用域中的this

事件中的this指向事件源

   <input type="button">
    <script>
        console.log(this)
        function fn() {
            console.log('函数中this')
            console.log(this)
        }
        fn()
        let btn = document.querySelector('input')
        btn.addEventListener('click', function () {
            console.log(this)

        })
    </script>

在这里插入图片描述
规律:哪个对象在调用这个方法,那么方法中的this就指向当前调用对象(谁调用就指向谁)

        let obj = {
            name: '老段',
            eat: function () {
                console.log(this)
            }
        }
        obj.eat()

在这里插入图片描述

回调函数

回调函数:本质是一个函数:如果我们将一个函数作为参数,当前这个函数就叫回调函数
高阶函数:还是一个函数,如果一个函数的参数是函数,那么这个函数就是高阶函数

事件

事件流

事件流就是事件的一种现象
事件流:事件冒泡现象,事件捕获现象

事件冒泡现象

1.在嵌套结构中,如果子元素事件会向外(父元素)传递,这个现象就叫事件冒泡现象
在嵌套结构中子元素向父元素传递
2.解决:如果遇到事件冒泡,而且冒泡对我们的程序产生了影响,我们可以阻止冒泡
阻止事件冒泡的时候,一定要给子元素阻止,阻止事件冒泡的语法:事件对象参数.stopPropagation();
点击子元素:

 <div class="one">
        <div class="two"></div>
    </div>
    <script>
        // 需求,点击两个盒子,分别输出一句话
        let one = document.querySelector('.one')
        let two = document.querySelector('.two')
        // 点击第一个盒子
        one.addEventListener('click', function () {
            console.log('我是父元素')

        })
        two.addEventListener('click', function () {

            console.log('我是子元素')
        })

    </script>

在这里插入图片描述

事件捕获

现象:和事件冒泡相反,在嵌套结构中,事件从父元素向子元素传递
注意:
1.事件程序中默认看不到事件捕获
2.如果要看到事件捕获,要求必需要用addEventListener注册事件,并且设置一个参数为true

事件捕获不用管,因为默认是事件冒泡

<div class="one">
        <div class="two"></div>
    </div>
    <script>
        // 需求,点击两个盒子,分别输出一句话
        let one = document.querySelector('.one')
        let two = document.querySelector('.two')
        // 点击第一个盒子
        one.addEventListener('click', function () {
            console.log('我是父元素')

        }, true);
        two.addEventListener('click', function () {

            console.log('我是子元素')
        }, true)

    </script>

点击子元素,先显示父元素
在这里插入图片描述

解绑事件

通过解绑事件,可以不执行事件中的代码

  <input type="button" value="按钮">
    <div></div>
    <script>
        let btn = document.querySelector('input')

        function fn() {
            console.log('123')
        }
        // 函数带括号则立刻执行
        btn.addEventListener('click', fn);
        // 解绑事件
        // a)如果注册事件通过addEventListener方式注册的,那么移除事件(解绑)通过
        // removeEventListener('事件类型',函数名)移除
        // 移除btn
        btn.removeEventListener('click', fn)
        // b)如果元素注册事件的时候,通过on方式注册的,那么解绑事件的时候
        // 通过语法:DOM对象.on事件类型=null
        
        // 总结 console.log(btn);输出的结构是以html标签的形式输出的
        // console.dir(btn)输出的结构是以对象格式输出的
    </script>

事件委托(★)

在注册事件的时候可以减少代码量

    <div>
        <ul>
            <li>1</li>
            <li>2</li>
            <li>3</li>
            <li>4</li>
        </ul>
    </div>
    <script>
        // 事件委托的实现步骤
        // 1.必须将事件给父元素注册(无所谓直接父元素还是间接父元素)
        // 2.必须找到真正的事件源(对应的标签对象),可以进行各种处理:事件对象参数.target

        // 要求:点击每一个li标签,输出li标签的内容
        // 不用事件委托实现
        // let lis = document.querySelectorAll('li')
        // for (let i = 0; i < lis.length; i++) {
        //     lis[i].addEventListener('click', function () {
        //         console.log(this.innerHTML)
        //     })
        // }

        // 事件委托实现
        let div = document.querySelector('div')
        div.addEventListener('click', function (e) {
            // 获得真正的事件源
            let li = e.target
            // 获取事件源内容
            console.log(li.innerHTML)

        })


    </script>

其他事件

页面加载事件:load

当页面中所有资源都加载完成之后,自动触发load事件
写法:window.addEventListener(‘load’,function(){})
应用场景:如果将获取标签的代码写到html结构(body)的前面,则必须加load事件
为什么获取标签的代码写到html结构前面必须加load事件才可以?
a)js的执行顺序是按照从上到下执行的
b)如何获取标签的代码写到head中,页面中还没有标签对象,会报错

页面加载事件:DOMContentLoaded

作用:当我们整个HTML文档加载完成后就会执行DOMContentLoaded事件
当初始的HTML文档被加载完成和解析完成之后,DOMContentLoaded事件被触发,而无需等待样式表、图像等完全加载
语法:document.addEventListener(‘DOMContentLoaded’,function(){})

页面滚动事件:scroll

语法:window.addEventListener(‘scroll’,function(){})
应用场景:拖拽滚动条,页面出现固定定位的导航

获取滚动距离
<script>
        // 获取滚动距离
        // 对象.scrollLeft 获取水平方向的滚动距离
        // 对象.scrollTop 获取垂直方向的滚动距离

        // 备注:1.获取滚动距离需要在滚动事件中获取
        // 2.如果给window注册滚动事件并获取滚动距离,不能通过window.scrollTop获取
        // 3,如果给window注册滚动事件并获取滚动距离,通过document.documentElement.scrollTop获取
        //4.获取到的滚动距离由两部分组成:
        window.addEventListener('scroll', function () {
            let lg = document.documentElement.scrollTop
            console.log(lg)

        })


    </script>

元素的尺寸与位置

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1504552.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Go语言数据结构(二)堆/优先队列

文章目录 1. container中定义的heap2. heap的使用示例3. 刷lc应用堆的示例 更多内容以及其他Go常用数据结构的实现在这里&#xff0c;感谢Star&#xff1a;https://github.com/acezsq/Data_Structure_Golang 1. container中定义的heap 在golang中的"container/heap"…

[数据集][目标检测]变电站缺陷检测数据集VOC+YOLO格式8307张17类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;8307 标注数量(xml文件个数)&#xff1a;8307 标注数量(txt文件个数)&#xff1a;8307 标注…

Java8 CompletableFuture异步编程-进阶篇

&#x1f3f7;️个人主页&#xff1a;牵着猫散步的鼠鼠 &#x1f3f7;️系列专栏&#xff1a;Java全栈-专栏 &#x1f3f7;️个人学习笔记&#xff0c;若有缺误&#xff0c;欢迎评论区指正 前言 我们在前面文章讲解了CompletableFuture这个异步编程类的基本用法&#xff0c;…

【操作系统概念】第11章:文件系统实现

文章目录 0.前言11.1 文件系统结构11.2 文件系统实现11.2.1 虚拟文件系统 11.3 分配方法11.3.1 连续分配11.3.2 链接分配11.3. 3 索引分配 11.5 空闲空间管理11.5.1 位图/位向量11.5.2 链表11.5.3 组 0.前言 正如第10章所述&#xff0c;文件系统提供了机制&#xff0c;以在线存…

【数据分享】2000-2022年全国1km分辨率的逐年PM2.5栅格数据(免费获取)

PM2.5作为最主要的空气质量指标&#xff0c;在我们日常研究中非常常用&#xff01;之前我们给大家分享了2013-2022年全国范围逐日的PM2.5栅格数据&#xff08;可查看之前的文章获悉详情&#xff09;&#xff01; 本次我们给大家带来的是2000-2022年全国范围的逐年的PM2.5栅格数…

树莓派4B Ubuntu20.04 Python3.9安装ROS踩坑记录

问题描述 在使用sudo apt-get update命令更新时发现无法引入apt-pkg,使用python3 -c "import apt_pkg"发现无法引入&#xff0c;应该是因为&#xff1a;20.04的系统默认python是3.8&#xff0c;但是我换成了3.9所以没有编译文件&#xff0c;于是使用sudo update-alte…

K8S - 在任意node里执行kubectl 命令

当我们初步安装玩k8s &#xff08;master 带 2 nodes&#xff09; 时 正常来讲kubectl 只能在master node 里运行 当我们尝试在某个 node 节点来执行时&#xff0c; 通常会遇到下面错误 看起来像是访问某个服务器的8080 端口失败了。 原因 原因很简单 , 因为k8s的各个组建&…

思科网络中如何配置标准ACL协议

一、什么是标准ACL协议&#xff1f;有什么作用及配置方法&#xff1f; &#xff08;1&#xff09;标准ACL&#xff08;Access Control List&#xff09;协议是一种用于控制网络设备上数据流进出的协议。标准ACL基于源IP地址来过滤数据流&#xff0c;可以允许或拒绝特定IP地址范…

微信私信短剧机器人源码

本源码仅提供参考&#xff0c;有能力的继续开发 接口为api调用 云端同步 https://ys.110t.cn/api/ajax.php?actyingshilist 影视搜索 https://ys.110t.cn/api/ajax.php?actsearch&name剧名 每日更新 https://ys.110t.cn/api/ajax.php?actDaily 反馈接口 https://ys.11…

机器学习-pytorch1(持续更新)

上一节我们学习了机器学习的线性模型和非线性模型的机器学习基础知识&#xff0c;这一节主要将公式变为代码。 代码编写网站&#xff1a;https://colab.research.google.com/drive 学习课程链接&#xff1a;ML 2022 Spring 1、Load Data&#xff08;读取数据&#xff09; 这…

Chain of Verification(验证链、CoVe)—理解与实现

原文地址&#xff1a;Chain of Verification (CoVe) — Understanding & Implementation 2023 年 10 月 9 日 GitHub 存储库 介绍 在处理大型语言模型&#xff08;LLM&#xff09;时&#xff0c;一个重大挑战&#xff0c;特别是在事实问答中&#xff0c;是幻觉问题。当答案…

排序算法全景:从基础到高级的Java实现

&#x1f31f; 前言 欢迎来到我的技术小宇宙&#xff01;&#x1f30c; 这里不仅是我记录技术点滴的后花园&#xff0c;也是我分享学习心得和项目经验的乐园。&#x1f4da; 无论你是技术小白还是资深大牛&#xff0c;这里总有一些内容能触动你的好奇心。&#x1f50d; &#x…

【红外与可见光融合:条件学习:实例归一化(IN)】

Infrared and visible image fusion based on a two-stage class conditioned auto-encoder network &#xff08;基于两级类条件自编码器网络的红外与可见光图像融合&#xff09; 现有的基于自动编码器的红外和可见光图像融合方法通常利用共享编码器从不同模态中提取特征&am…

Java17 --- springCloud之LoadBalancer

目录 一、LoadBalancer实现负载均衡 1.1、创建两个相同的微服务 1.2、在客户端80引入loadBalancer的pom 1.3、80服务controller层&#xff1a; 一、LoadBalancer实现负载均衡 1.1、创建两个相同的微服务 1.2、在客户端80引入loadBalancer的pom <!--loadbalancer-->&…

ARTS Week 20

Algorithm 本周的算法题为 1222. 可以攻击国王的皇后 在一个 下标从 0 开始 的 8 x 8 棋盘上&#xff0c;可能有多个黑皇后和一个白国王。 给你一个二维整数数组 queens&#xff0c;其中 queens[i] [xQueeni, yQueeni] 表示第 i 个黑皇后在棋盘上的位置。还给你一个长度为 2 的…

js【详解】async await

为什么要使用 async await async await 实现了使用同步的语法实现异步&#xff0c;不再需要借助回调函数&#xff0c;让代码更加易于理解和维护。 (async function () {// await 必须放在 async 函数中try {// 加载第一张图片const img1 await loadImg1()// 加载第二张图片co…

Linux网络套接字之UDP网络程序

(&#xff61;&#xff65;∀&#xff65;)&#xff89;&#xff9e;嗨&#xff01;你好这里是ky233的主页&#xff1a;这里是ky233的主页&#xff0c;欢迎光临~https://blog.csdn.net/ky233?typeblog 点个关注不迷路⌯▾⌯ 实现一个简单的对话发消息的功能&#xff01; 目录…

力扣---腐烂的橘子

题目&#xff1a; bfs思路&#xff1a; 感觉bfs还是很容易想到的&#xff0c;首先定义一个双端队列&#xff08;队列也是可以的~&#xff09;&#xff0c;如果值为2&#xff0c;则入队列&#xff0c;我这里将队列中的元素定义为pair<int,int>。第一个int记录在数组中的位…

毅速3D打印随形透气钢:模具困气排气革新之选

在注塑生产过程中&#xff0c;模具内的气体若无法有效排出&#xff0c;往往会引发困气现象&#xff0c;导致产品表面出现气泡、烧焦等瑕疵。这些瑕疵不仅影响产品的美观度&#xff0c;更可能对其性能造成严重影响&#xff0c;甚至导致产品报废&#xff0c;从而增加生产成本。 传…

【C语言】linux内核tcp_write_xmit和tcp_write_queue_purge

tcp_write_xmit 一、讲解 这个函数 tcp_write_xmit 是Linux内核TCP协议栈中的一部分&#xff0c;其基本作用是发送数据包到网络。这个函数会根据不同情况推进发送队列的头部&#xff0c;确保只要远程窗口有空间&#xff0c;就可以发送数据。 下面是对该函数的一些主要逻辑的中…