JavaScript基础——事件高级
注册事件
注册事件概述
给元素添加事件,称为注册事件或者绑定事件
注册事件有两种方式:传统方式和方法监听注册方式。
传统注册方式
利用on开头的事件,例如onclick
1.第一种
<button onclick='alert("HelloWorld!")'>按钮</button>
2.第二种
btn.onclick= function(){}
特点
注册事件的唯一性
同一个元素同一个事件只能设置一个处理函数,最后注册的处理函数将会覆盖前面注册的处理函数。
方法监听事件注册方式
W3C标准 推荐方式
addEventListener()
是一个方法
IE9之间的IE不支持此方法,可使用attachEvent()
代替
特点
同一个元素,同一个事件,可以注册多个监听器,按注册顺序依次执行
addEventListener 事件监听方式
eventTarget.addEventListener(type,listener[,useCapture])
eventTarget.addEventListener()
方法将指定的监听器注册到eventTarget(目标对象)上,当该对象被处罚指定的实践的时候,就会执行事件处理函数。
该方法接收三个参数:
listener: 事件处理函数,事件发生时,会调用该监听函数
useCapture: 可选参数,是一个布尔值,默认是false。日后补充
attachEvent事件监听方式
eventTarget.attachEvent(eventNameWithOn,callback)
eventTarget.attachEvent()
方法将指定的监听器注册到eventTarget(目标对象)上,当该对象触发指定的事件时,指定的回调函数就会被执行。
该方法接收两个参数:
callback: 事件处理函数,当目标触发事件则回调函数被调用
注册事件兼容性解决方案
function addEventListener(element,eventName,fn){ // 判断当前流浪器是否支持addEventListener方法 if(element.addEventListener){ element.addEventListener(eventName,fn); }else if (element.attachEvent){ element.attachEvent('on'+eventName+eventName,fn); }else{ // 相当于element.onclick=fn; element['on'+eventName].fn; } }
兼容性处理原则:首先照顾大多数浏览器,在处理特殊浏览器。
删除事件(解绑事件)
传统删除方式
eventTarget.onclick = null;
方法监听删除方式
removeEventListener事件监听方式
eventTarget.removeEventListener(type,listener[,useCapture]);
detachEvent事件监听方式
eventTarget.detachEvent(eventNameWithOn,callback);
可以看到删除事件的方式和注册事件的如出一辙。
当然删除事件也是需要照顾兼容性问题的
function removeEventListener(element,eventName,fn){ if(element.removeEventListener){ element.removeEventListener(eventName,fn); }else if (element.attachEvent){ element.detachEvent('on'+eventName+eventName,fn); }else{ element['on'+eventName] = null; } }
DOM事件流
事件流描述的是从页面中接收事件的顺序。
事件发生时会在元素节点之间按照特定的顺序传播,这个传播过程即DOM事件流。
DOM事件流分为3个阶段:
- 捕获阶段
- 当前目标阶段
- 冒泡阶段
事件冒泡:IE最早提出,事件开始时由最具体的元素接收,然后逐级向上传播到DOM最顶层节点的过程。
事件捕获:网景最早提出,由DOM最顶层节点开始,然后逐级向下传播到最具体元素接收的过程。
1.js代码中只能执行捕获或者冒泡其中的一个阶段
2.onclick和attachEvent只能得到冒泡阶段。
3.addEventListener(type,listener[,useCapture])第三个参数如果是true,表示在实践捕获阶段调用事件处理程序;如果是false(不写默认就是false),表示在事件冒泡阶段调用事件处理程序
4.在实际开发中,很少使用事件捕获,更多关注的是事件管理。 5.有些事件是没有冒泡的,比如onblur、onfocus、onmouseenter、onmouseleave。
事件对象
事件对象的概念
eventTarget.onclick = function(event){} eventTarget.addEventListener('click',function(event){})
官方解释:event对象代表事件的状态,比如键盘按键的状态、鼠标的位置、鼠标按钮的状态。
简单理解:事件发生后进,跟事件相关的一系列信息数据的集合都放到这个对象里面,这个对象就是事件对象event,它有很多的属性和方法。
比如:
1.谁绑定了这个事件
2.鼠标触发事件的话,会得到鼠标的相关信息,如鼠标位置。
3.键盘触发事件的话,会得到键盘的相关信息,如按了哪个键。
事件对象兼容性方案
事件对象本身的获取存在兼容问题:
1.标准浏览器中是浏览器给方法传递的参数,只需要定义形参e就可以获取到。
2.在IE6~8中,浏览器不会给方法传递参数,如果需要的话,需要到window.event中获取查找。
解决:
e = e || window.event;
事件对象的常见属性和方法
事件对象属性方法 | 说明 |
---|---|
e.target |
返回触发事件的对象 标准 |
e.srcElement |
返回触发事件的对象 非标准ie6~8使用 |
e.type |
返回事件的类型 比如click mouseover 不带on |
e.cancelBubble |
该属性阻止冒泡 非标准 ie6~8使用 |
e.returnValue |
该属性阻止默认事件(默认行为) 非标准 ie6~8使用 比如不让链接跳转 |
e.preventDefault() |
该方法 阻止默认事件(默认行为) 标准 比如不让链接跳转 |
e.stopPropagation() |
阻止冒泡 标准 |
触发事件对象兼容性写法
eventTarget.onlick = function(e){ e = e||window.event; var target = e.target || e.srcElement; console.log(target); }
this获取绑定对象
this
指向的是绑定事件的对象。
div.addElementListener('onclick',function(e){ console.log(this); });
如上述代码所示,绑定事件的对象是div
,那么输出的就是div
。
阻止默认行为
除了e.preventDefault()
以及e.e.returnValue
可以用于阻止事件默认行为外,还有将所绑定的事件返回值改为false
以此达到阻止事件的目的。
特点:return
后面的代码不执行了
阻止事件冒泡的两种方式
标准写法
使用事件对象里面的stopPropagation()
方法阻止冒泡。
如下所示:
eventTarget.addEventListener('click',function(e){ e.stopPropagation(); });
非标准写法 ie6~8使用
更改事件对象里面的cancelBubble
属性的属性值为true
阻止冒泡。
如下所示:
eventTarget.addEventListener('click',function(e){ e.cancelBubble = true; });
照顾兼容性写法
eventTarget.addEventListener('click',function(e){ if(e&&e.stopPropagation()){ e.stopPropagation(); }else{ window.event.cancelBubble = true; } });
事件委托(代理、委派)
事件委托
事件委托也成为了事件代理,在JQuery里面称为事件委派。
事件委托的原理
<!--html部分--> <ul id='studentList'> <li id='student01'>学生1</li> <li id='student02'>学生2</li> <li id='student03'>学生3</li> ... <li id='student04'>学生4</li> </ul>
// js部分 var stuList = document.getElementById('studentList'); stuList.addEventListener('click',function(e){ alert('点击了'+e.target.innerText); })
常用鼠标事件
鼠标事件 | 触发条件 |
---|---|
onclick | 鼠标点击左键触发 |
onmouseover | 鼠标经过触发 |
onmouseout | 鼠标离开触发 |
onfocus | 获得鼠标焦点触发 |
onblur | 失去鼠标焦点触发 |
onmousemove | 鼠标移动触发 |
onmouseup | 鼠标弹起触发 |
onmousedown | 鼠标按下触发 |
禁止鼠标右键菜单
contextmenu
主要控制应该何时显示上下文菜单,主要用于程序员取消默认的上下文菜单
如下所示:
document.addEventListener('contextmenu',function(e){ e.preventDefault(); });
禁止鼠标选中(selectstart 开始选中)
document.addEventListener('selectstart',function(e){ e.preventDefault(); });
鼠标事件对象
鼠标事件对象 | 说明 |
---|---|
e.clientX | 返回鼠标相对于浏览器窗口可视区的X坐标 |
e.clientY | 返回鼠标相对于浏览器窗口可视区的Y坐标 |
e.pageX | 返回鼠标相对于文档页面中的X坐标 IE9+支持 |
e.pageY | 返回鼠标相对于文档页面中的Y坐标 IE9+支持 |
e.screenX | 返回鼠标相对于电脑屏幕的X坐标 |
e.screenY | 返回鼠标相对于电脑屏幕的Y坐标 |
常用键盘事件
事件除了鼠标触发,还可以使用键盘触发。
键盘事件 | 触发条件 |
---|---|
onkeyup | 某个按键被松开时触发 |
onkeydonwn | 某个按键被按下时触发 |
onkeypress | 某个按键被按下时触发 但是不能识别功能键 比如ctrl+shift箭头等 |
键盘事件对象
键盘事件对象属性 | 说明 |
---|---|
keyCode | 返回该键的ASCII值 |
codeonkeydown
以及onkeyup
的事件对象keyCode
属性值是不区分字母大小写的,而onkeypress
,无法识别功能键
本文来自博客园,作者:maplerain,转载请注明原文链接:https://www.cnblogs.com/maplerain/p/16282347.html 博主B站
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南