当前位置: 首页 > news >正文

JS-第十九天-事件(一)

一、事件基础概念

1.1 事件三要素

  • 事件源:触发事件的元素

  • 事件类型:事件的种类(如click、mouseover等)

  • 事件处理程序:响应事件的函数

1.2 事件流机制

事件传播分为三个阶段:

  1. 捕获阶段:事件从顶层开始,经过所有祖先节点,直至触发目标节点

  2. 目标阶段:事件到达目标节点并触发

  3. 冒泡阶段:事件从目标节点开始,经过所有祖先节点,直至顶层Window对象

二、事件绑定方式

2.1 三种绑定方法对比

方法

语法添加数量移除方式特点
HTML行内onclick="console.log('点击')"1个直接删除属性简单但耦合度高
DOM属性ele.onclick = function(){}1个ele.onclick = null简单,但只能绑定一个
addEventListenerele.addEventListener(event, fn, options)多个removeEventListener()推荐,功能最强大

2.2 推荐使用 addEventListener

// 添加事件监听器
element.addEventListener('click', function(event) {console.log('点击事件');
}, false);
​
// 移除事件监听器
element.removeEventListener('click', handlerFunction);

三、常用事件类型

3.1 鼠标事件

  • click - 单击

  • dblclick - 双击

  • contextmenu - 右键菜单

  • mouseover/mouseout - 鼠标移入/移出(会冒泡)

  • mouseenter/mouseleave - 鼠标进入/离开(不冒泡)

  • mousedown/mouseup - 鼠标按下/释放

  • mousemove - 鼠标移动

重要区别mouseenter/mouseleave 不会冒泡,不受子元素影响;mouseover/mouseout 会冒泡,受子元素影响。

  <script>//  click 鼠标点击//  dblclick 鼠标双击document.ondblclick = function () {console.log('鼠标双击');}// contextmenu 右击菜单document.oncontextmenu = function () {console.log('右键');document.oncontextmenu('.right').style.display = 'block'// 事件原本的功能【阻止默认行为】event.preventDefault()}// mouseover/mouseout 鼠标移入/移出(会冒泡)document.querySelector('.box').onmouseover = function () {console.log('over鼠标滑上去');}document.querySelector('.box').onmouseout = function () {console.log('out鼠标滑出去');}// mouseenter/mouseleave 鼠标移入/移出(不会冒泡)document.querySelector('.box').onmouseenter = function () {console.log('enter鼠标滑走');}document.querySelector('.box').onmouseleave = function () {console.log('leave鼠标滑离开');}// mousedown/mouseup 鼠标按下/释放document.querySelector('.box').onmousedown = function () {console.log('down鼠标按下');}document.querySelector('.box').onmouseup = function () {console.log('up鼠标释放');}// mousemove 鼠标移动document.querySelector('.box').onmousemove = function () {console.log('move鼠标移动');}</script>

3.2 键盘事件

  • keydown - 键盘按下

  • keyup - 键盘弹起

  • keypress - 按到有效字符

    // keydown 键盘按下document.onkeydown = function () {console.log('down')}// keyup 键盘弹起document.onkeyup = function () {console.log('keyup')}// keypress 按到有效字符document.onkeypress = function (e) {//函数有个参数代表事件的对象console.log('press')console.log(e.key)console.log(e.keyCode)}

3.3 表单事件

  • submit - 表单提交

  • focus/blur - 获得/失去焦点

  • change - 值发生改变

  • input - 输入事件

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>.tip {color: darkgreen;}.err {color: red;}</style>
</head><body><!-- 表单 --><form id="form" action="https://www.baidu.com">用户名:<input type="text" name="n"><br>密码:<input type="password" name="p"><br><span class="tip" hidden>请输入密码</span><br><span class="err" hidden>密码不正确</span><br><button id="btn" type="submit">按钮</button></form><script>form.onsubmit = function (e) {e.preventDefault();//阻止提交}// 输入document.querySelector('input')[0].oninput = function () {console.log('输入')}// 获取焦点,失去焦点 focus/blurdocument.querySelectorAll('input')[1].onfocus = function () {document.querySelector('.tip').hidden = falsedocument.querySelector('.err').hidden = true}document.querySelectorAll('input')[1].onblur = function () {document.querySelector('.tip').hidden = truedocument.querySelector('.err').hidden = false}// change 当值发生改变时触发document.querySelectorAll('input')[1].onchange = function () {console.log('变了。')}</script><!-- 以下全部适合用change监听 --><input type="checkbox"><input type="radio"><select name="" id=""></select>
</body></html>

http://www.xdnf.cn/news/1226521.html

相关文章:

  • 通过观看数百个外科手术视频课程来学习多模态表征|文献速递-医学影像算法文献分享
  • 从0开始学习R语言--Day64--决策树回归
  • 【2025/08/01】GitHub 今日热门项目
  • Android使用MediaProjectionManager获取游戏画面和投屏
  • 应用药品注册证识别技术,为医药行业的合规、高效与创新发展提供核心驱动力
  • TwinCAT3示例项目1
  • 探索 VMware 虚拟机:开启虚拟化世界的大门
  • 学习游戏制作记录(各种水晶能力以及多晶体)8.1
  • 新手小白如何快速检测IP 的好坏?
  • Vue2 项目实现 Gzip 压缩全攻略:从配置到部署避坑指南
  • 基于coze studio开源框架二次定制开发教程
  • 【MySQL索引失效场景】索引失效原因及最左前缀原则详解
  • OSPF综合实验报告册
  • Qt 开发 IDE 插件开发指南
  • 【文章素材】3dBackgroundBoxes(3D背景盒子组件)项目及文章思路
  • 从游戏NPC到手术助手:Agent AI重构多模态交互,具身智能打开AGI新大门
  • Spring之【循环引用】
  • SpringCloud(一)微服务基础认识
  • Transformer架构全解析:搭建AI的“神经网络大厦“
  • 从零到英雄:掌握神经网络的完整指南
  • Spotlight on MySQL 300安装教程(附使用指南):实时监控MySQL性能的工具
  • 60 GHz DreamHAT+ 雷达已被正式批准为“Powered by Raspberry Pi”产品
  • 学习笔记:原子操作与锁以及share_ptr的c++实现
  • 下载一个JeecgBoot-master项目 导入idea需要什么操作启动项目
  • 小杰数据结构(four day)——藏器于身,待时而动。
  • 十、SpringBootWeb快速入门-入门案例
  • 李宏毅深度学习教程 第4-5章 CNN卷积神经网络+RNN循环神经网络
  • 大模型开发框架LangChain之构建知识库
  • 暑期算法训练.12
  • 人员定位卡人脸智能充电发卡机