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

环境对象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('事件类型',函数名)移除// 移除btnbtn.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.scrollTopconsole.log(lg)})</script>

元素的尺寸与位置

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

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

相关文章

开发指南002-前后端信息交互规范-概述

前后端之间采用restful接口&#xff0c;服务和服务之间使用feign。信息交互遵循如下平台规范&#xff1a; 前端&#xff1a; 建立api目录&#xff0c;按照业务区分建立不同的.js文件&#xff0c;封装对后台的调用操作。其中qlm*.js为平台预制的接口文件&#xff0c;以qlm_user.…

MySQL--explain执行计划详解

什么是执行计划&#xff1f; SQL的执行计划&#xff0c;通俗来说就是SQL的执行情况&#xff0c;一条SQL语句扫描哪些表&#xff0c;那个子查询先执行&#xff0c;是否用到了索引等等&#xff0c;只有当我们知道了这些情况之后才知道&#xff0c;才可以更好的去优化SQL&#xf…

java 数据结构二叉树

目录 树 树的概念 树的表示形式 二叉树 两种特殊的二叉树 二叉树的性质 二叉树的存储 二叉树的基本操作 二叉树的遍历 二叉树的基本操作 二叉树oj题 树 树是一种 非线性 的数据结构&#xff0c;它是由 n &#xff08; n>0 &#xff09;个有限结点组成一个具有层次…

伪分布Hadoop的安装与部署

1.实训目标 &#xff08;1&#xff09;熟悉掌握使用在Linux下安装JDK。 &#xff08;2&#xff09;熟悉掌握使用在Linux下安装Hadoop。 &#xff08;3&#xff09;熟悉掌握使用配置SSH免密登录。 2.实训环境与软件 环境 版本 说明 Windows 10系统 64位 操作电脑配置 …

前端vite+vue3——可视化页面性能耗时指标(fmp、fp)

文章目录 ⭐前言&#x1f496;vue3系列文章 ⭐可视化fmp、fp指标&#x1f496; MutationObserver 计算 dom的变化&#x1f496; 使用条形图展示 fmp、fp时间 ⭐项目代码⭐结束 ⭐前言 大家好&#xff0c;我是yma16&#xff0c;本文分享关于 前端vitevue3——可视化页面性能耗时…

图像处理与图像分析—图像的读入(C语言)

学习将会依据教材图像处理与图像分析基础&#xff08;C/C&#xff09;版内容展开 什么是数字图像处理 一副图像可以定义为一个二维函数 f(x&#xff0c;y) &#xff0c;其中 x 和 y 是空间&#xff08;平面&#xff09;坐标&#xff0c;任意一对空间坐标 (x,y) 处的幅度值 &am…

微信私信短剧机器人源码

本源码仅提供参考&#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…

R语言复现:中国Charls数据库一篇现况调查论文的缺失数据填补方法

编者 在临床研究中&#xff0c;数据缺失是不可避免的&#xff0c;甚至没有缺失&#xff0c;数据的真实性都会受到质疑。 那我们该如何应对缺失的数据&#xff1f;放着不管&#xff1f;还是重新开始?不妨试着对缺失值进行填补&#xff0c;简单又高效。毕竟对于统计师来说&#…

NUC980开发板CAN开发笔记

一、内核开启CAN CAN 设置 NUC980 系列带有2个CAN(Controller Area Network), 可以分别独立设置。 请按以下的说明来使能CAN功能. 每个CAN可以单独的开关. CAN0有多组管脚可以选择, 需要一并设置。 使用者也可以设置CAN的唤醒功能。步骤如下&#xff1a; 进入 NUC980-linux-4.…

使用Tokeniser估算GPT和LLM服务的查询成本

将LLM集成到项目所花费的成本主要是我们通过API获取LLM返回结果的成本&#xff0c;而这些成本通常是根据处理的令牌数量计算的。我们如何预估我们的令牌数量呢&#xff1f;Tokeniser包可以有效地计算文本输入中的令牌来估算这些成本。本文将介绍如何使用Tokeniser有效地预测和管…

异步编程实战:使用C#实现FTP文件下载及超时控制

博客标题: 异步编程实战&#xff1a;使用C#实现FTP文件下载及超时控制 如果你的函数不是async&#xff0c;你仍然可以实现相同的超时功能&#xff0c;但你将不得不依赖更多的同步代码或使用.Result或.GetAwaiter().GetResult()来阻塞等待任务完成&#xff0c;这可能导致死锁的风…

verilog中的函数和for循环

在Verilog中&#xff0c;clogb2 的英文全称是 “ceiling&#xff08;天花板&#xff09; log base 2”&#xff0c;表示对输入参数取对数&#xff08;以2为底&#xff09;&#xff0c;并向上取整到最接近的整数值。这个函数通常用于计算内存地址宽度或状态数所需的位数12。 fun…

STM32---通用定时器(二)相关实验

写在前面&#xff1a;前面我们学习了基本定时器、通用定时器的相关理论部分&#xff0c;了解到通用定时器的结构框图&#xff0c;总共包含六大模块&#xff1a;时钟源、控制器、时基单元、输入捕获、公共部分以及输出捕获。对相关模块的使用也做详细的讲解。本节我们主要是对上…

Day33-计算机基础3

Day33-计算机基础3 1.根据TCP/IP进行Linux内核参数优化1.1 例1&#xff1a;调整访问服务端的【客户端】的动态端口范围 &#xff0c;LVS&#xff08;10-50万并发&#xff09;&#xff0c;NGINX负载&#xff0c;SQUID缓存服务,1.2 企业案例&#xff1a;DOS攻击的案例&#xff1a…

[备赛笔记]——5G大唐杯(5G考试等级考考试基础试题)

个人名片&#xff1a; &#x1f981;作者简介&#xff1a;学生 &#x1f42f;个人主页&#xff1a;妄北y &#x1f427;个人QQ&#xff1a;2061314755 &#x1f43b;个人邮箱&#xff1a;2061314755qq.com &#x1f989;个人WeChat&#xff1a;Vir2021GKBS &#x1f43c;本文由…

redis缓存满了的话会发生什么?

线上问题 未及时加监控&#xff0c;导致线上redis被逐出&#xff0c;业务有损 示例&#xff1a; 一个key临时存储在redis等缓存中&#xff0c;如果该key在一段时间内有很大作用 比如一次业务请求&#xff0c;上游服务写入一个value&#xff0c;时长1小时&#xff0c;下游服务…

Matlab|考虑源荷两侧不确定性的含风电电力系统低碳调度

目录 1 主要内容 目标函数&#xff1a; 约束条件&#xff1a; 程序亮点总结&#xff1a; 2 代码问题与程序测试 设备出力运行结果&#xff1a; 3 下载链接 1 主要内容 本程序是对《考虑源荷两侧不确定性的含风电电力系统低碳调度》的方法复现&#xff0c;主要实现了基…

【QT+QGIS跨平台编译】之七十六:【QGIS_Native+Qt跨平台编译】(一套代码、一套框架,跨平台编译)

文章目录 一、QGIS_Native介绍二、QGIS下载三、文件分析四、pro文件五、编译实践一、QGIS_Native介绍 QGIS_Native模块是QGIS软件的核心部分,提供了许多基本功能和核心组件,主要用于处理与底层操作系统的关系。 二、QGIS下载 QGIS网址: QGIS Source Download 三、文件分析…

Django学习笔记

Django学习笔记 一、Django整体流程跑通 1.1安装 pip install django //安装 import django //在python环境中导入django django.get_version() //获取版本号&#xff0c;如果能获取到&#xff0c;说明安装成功Django目录结构 Python310-Scripts\django-admi…

前端框架的发展历程

文章目录 前言 一、静态页面时代 二、JavaScript的兴起 三、jQuery的出现 四、前端框架的崛起 1.AngularJS 2.React 3.Vue.js 五、面向组件化的发展趋势 总结 前言 前端框架的发展史就是一个不断进化的过程&#xff0c;它的发展和进化一定程度…