news 2026/3/7 11:12:45

web APIs第三天

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
web APIs第三天

(详细资料和相关课程可搜b站黑马程序员)

一、事件流

1.事件流与两个阶段说明

事件流指的是事件完整执行过程中的流动路径

说明:假设页面里有个div,当触发事件时,会经历两个阶段,分别是捕获阶段、冒泡阶段

简单来说:捕获阶段是 从父到子 冒泡阶段是从子到父

实际工作都是使用事件冒泡为主

2.事件捕获

事件捕获概念:从DOM的根元素开始去执行对应的事件 (从外到里)
addEventListener第三个参数传入true代表是捕获阶段触发(很少使用)

3.事件冒泡

事件冒泡:当一个元素的事件被触发时,同样的事件将会在该元素的所有祖先元素中依次被触发。这一过程被称为事件冒泡

简单理解:当一个元素触发事件后,会依次向上调用所有父级元素的同名事件

4.阻止冒泡

因为默认就有冒泡模式的存在,所以容易导致事件影响到父级元素
若想把事件就限制在当前元素内,就需要阻止事件冒泡
阻止事件冒泡需要拿到事件对象
语法:
此方法可以阻断事件流动传播,不光在冒泡阶段有效,捕获阶段也有效
使用:我们某些情况下需要阻止默认行为的发生,比如 阻止链接的跳转,表单域跳转

5.解绑事件

addEventListener方式,必须使用:
语法:removeEventListener(事件类型, 事件处理函数, [获取捕获或者冒泡阶段])
6.鼠标经过事件的区别

二、事件委托

事件委托是利用事件流的特征解决一些开发需求的知识技巧
优点:减少注册次数,可以提高程序性能
原理:事件委托其实是利用事件冒泡的特点。
给父元素注册事件,当我们触发子元素的时候,会冒泡到父元素身上,从而触发父元素的事件
实现:事件对象.target. tagName 可以获得真正触发事件的元素

三、其他事件

1.页面加载事件

(1)加载外部资源(如图片、外联CSS和JavaScript等)加载完毕时触发的事件
事件名:load
监听页面所有资源加载完毕:给 window 添加 load 事件
注意:不光可以监听整个页面资源加载完毕,也可以针对某个资源绑定load事件
(2)当初始的 HTML 文档被完全加载和解析完成之后,DOMContentLoaded 事件被触发,而无需等待样式表、图像等完全加载
事件名:DOMContentLoaded
监听页面DOM加载完毕:给 document 添加 DOMContentLoaded 事件

2.元素滚动事件

(1)滚动条在滚动的时候持续触发的事件
事件名:scroll
监听整个页面滚动:给 window 或 document 添加 scroll 事件
监听某个元素的内部滚动直接给某个元素加即可
(2)页面滚动事件-滚动到指定的坐标
scrollTo() 方法可把内容滚动到指定的坐标
语法:元素.scrollTo(x, y)

3.页面尺寸事件

会在窗口尺寸改变的时候触发事件:resize
页面尺寸事件-获取元素宽高
获取宽高:获取元素的可见部分宽高(不包含边框,margin,滚动条等);
clientWidth和clientHeight

四、元素尺寸位置

1.使用场景:前面案例滚动多少距离,都是我们自己算的,最好是页面滚动到某个元素,就可以做某些事。简单说,就是通过js的方式,得到元素在页面中的位置;这样我们可以做,页面滚动到这个位置,就可以做某些操作,省去计算了。
获取宽高:(1)获取元素的自身宽高、包含元素自身设置的宽高、padding、border。
(2)offsetWidth和offsetHeight
(3)获取出来的是数值,方便计算。注意: 获取的是可视宽高, 如果盒子是隐藏的,获取的结果是0
获取位置:(1)获取元素距离自己定位父级元素的左、上距离
(2)offsetLeft和offsetTop 注意是只读属性
(3)element.getBoundingClientRect() 方法返回元素的大小及其相对于视口的位置
2.其他方法
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/4 3:54:48

LobeChat能否集成潮汐信息?沿海地区活动安排建议

LobeChat能否集成潮汐信息?沿海地区活动安排建议 在福建连江的清晨,渔民老陈站在码头边皱眉翻着手机——他需要知道今天退潮的时间是否适合下滩挖蛤蜊,还得看风浪大不大、天气好不好。可他得先打开一个App查潮汐,再切到另一个看天…

作者头像 李华
网站建设 2026/3/7 7:43:03

GEE训练教程:利用 Google Earth Engine 分析广州地区植被动态变化(2016-2025)

利用 Google Earth Engine 分析广州地区植被动态变化(2016-2025) 一、项目概述 本文将通过 Google Earth Engine(GEE)平台,结合 Sentinel-2 卫星遥感数据,对广州地区的植被覆盖状况进行长达十年的动态监测。我们将从数据准备、预处理到植被指数计算,完整展示如何利用云…

作者头像 李华
网站建设 2026/3/3 17:18:53

WordPress跨平台兼容OA系统word上传需求

要求:开源,免费,技术支持 博客:WordPress 开发语言:PHP 数据库:MySQL 功能:导入Word,导入Excel,导入PPT(PowerPoint),导入PDF,复制粘贴word,导入微信公众号内容,web截屏 平台:Window…

作者头像 李华
网站建设 2026/3/3 18:29:08

BGP 基础配置示例

在路由器上启用 BGP 并配置基本参数,指定本地自治系统号(ASN)和 BGP 路由器 ID。BGP 路由器 ID 通常使用环回接口地址或物理接口地址。router bgp 65001bgp router-id 1.1.1.1no bgp default ipv4-unicast邻居关系建立配置 BGP 邻居&#xff…

作者头像 李华
网站建设 2026/3/5 13:52:30

目标检测——锚框

基于锚框的目标检测: 在图像中随机生成很多个锚框,首先预测锚框内是否含有目标然后预测锚框与目标真实的边缘框的偏移生成锚框后,通过IoU(交并比)来计算两个框之间的相似度,0表示无重叠,1表示重合IoUArea(A∩B)/Area(A…

作者头像 李华