(详细资料和相关课程可搜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.其他方法