news 2026/4/23 7:06:08

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/4/12 4:49:34

Spring boot学习心得

一、引言:为什么 Spring Boot 是 Java 开发者的必备技能? Spring Boot 作为 Spring 生态的核心子项目,以 “约定优于配置” 为核心理念,彻底解决了传统 Spring 框架配置繁琐、依赖冲突等痛点。截至 2024 年,Spring Bo…

作者头像 李华
网站建设 2026/4/9 16:58:32

LobeChat网页标题优化建议

LobeChat 技术架构与应用实践深度解析 在大语言模型(LLM)能力不断突破的今天,用户对 AI 交互体验的期待早已超越“能回答问题”这一基本要求。从智能客服到企业知识助手,越来越多的应用场景需要一个既强大又灵活的前端界面来承载复…

作者头像 李华
网站建设 2026/4/18 21:08:48

健身计划定制:LobeChat根据目标推荐动作

健身计划定制:LobeChat根据目标推荐动作 在智能健身设备和健康管理App层出不穷的今天,用户却越来越感到“被模板化”——无论你是刚入门的新手,还是有明确增肌减重目标的进阶者,收到的训练建议往往千篇一律。真正个性化的指导似乎…

作者头像 李华
网站建设 2026/4/9 22:41:44

WordPress处理ppt幻灯片转存到html富文本

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

作者头像 李华
网站建设 2026/4/20 21:11:45

LobeChat能否撰写道歉信?品牌形象修复助手

LobeChat能否撰写道歉信?品牌形象修复助手 在一次突发的系统故障后,某电商平台数小时内收到上千条客户投诉——订单丢失、支付异常、客服无响应。公关团队争分夺秒地准备对外声明,但措辞稍有不慎就可能激化舆情。此时,一名运营人员…

作者头像 李华
网站建设 2026/3/26 2:10:32

LobeChat能否部署在Oracle Cloud?免费资源利用攻略

LobeChat能否部署在Oracle Cloud?免费资源利用攻略 在AI应用门槛不断降低的今天,越来越多开发者开始尝试搭建属于自己的智能对话系统。但现实问题也随之而来:闭源平台如OpenAI虽然强大,却存在数据外泄风险、调用成本高和定制受限等…

作者头像 李华