news 2026/6/15 17:03:01

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/6/14 2:46:28

抖音下载器完整使用指南:从零开始保存高清内容

抖音下载器完整使用指南:从零开始保存高清内容 【免费下载链接】douyin-downloader 项目地址: https://gitcode.com/GitHub_Trending/do/douyin-downloader 你是否曾经在抖音上看到精彩的短视频或直播,想要保存下来反复观看却无从下手&#xff1…

作者头像 李华
网站建设 2026/6/12 21:53:49

ARM 架构中的浮点寄存器(Floating-Point Registers)

ARM 架构中的浮点寄存器(Floating-Point Registers) 一、基础概念解释 1.1 什么是浮点运算? 基础概念: 整数运算:处理整数(1, 2, 100, -5等),没有小数点浮点运算:处理实数…

作者头像 李华
网站建设 2026/6/14 16:41:33

VirtualMonitor虚拟显示器:终极多屏工作空间解决方案

VirtualMonitor虚拟显示器:终极多屏工作空间解决方案 【免费下载链接】VirtualMonitor 项目地址: https://gitcode.com/gh_mirrors/vi/VirtualMonitor 还在为单屏幕切换应用的繁琐操作而苦恼?VirtualMonitor虚拟显示器为您带来革命性的多屏解决方…

作者头像 李华
网站建设 2026/6/15 12:09:26

Switch界面美化终极指南:5分钟打造专属游戏空间

还在为Switch单调的界面而烦恼吗?🎮 每天面对相同的背景和布局,是不是觉得缺少了点个性?别担心,今天我就来帮你解决这个问题!通过简单的美化工具和界面定制技巧,让你的Switch焕然一新✨ 【免费下…

作者头像 李华
网站建设 2026/6/15 6:21:36

打造专属AI客服:基于LobeChat与GPU算力的完整方案

打造专属AI客服:基于LobeChat与GPU算力的完整方案 在企业服务智能化浪潮中,一个真实而紧迫的问题正不断浮现:如何在保障数据安全的前提下,构建响应迅速、可扩展且成本可控的AI客服系统?许多公司曾寄希望于OpenAI等云服…

作者头像 李华