学习笔记整理-DOM-02-事件监听

news2024/11/24 7:03:34

一、什么是"事件监听"

  • DOM允许书写JavaScript代码以让HTML元素对事件作出反应
  • 什么是"事件": 用户与网页的交互动作
  • 当用户点击元素时
  • 当鼠标移动到元素上时
  • 当文本框的内容被改变时
  • 当键盘在文本框中被按下时
  • 当网页已加载完毕时
  • “监听”,顾名思义,就是让计算机随时能够发现这个事件发生了,从而执行程序员预先编写的一些程序。

  • 设置事件监听的方法主要有onxxxaddEventListener()两种,

  • 常见的鼠标事件监听

    事件名事件描述
    onclick当鼠标单击某个对象
    ondblclick当鼠标双击某个对象
    onmousedown当某个鼠标按键在某个对象上被按下
    onmouseup当某个鼠标按键在某个对象上被松开
    onmousemove当某个鼠标按键在某个对象上被移动
    onmouseenter当鼠标进入某个对象(相似事件onmouseover)
    onmouseleave当鼠标离开某个对象(相似事件onmouseout)
  • 常见的键盘事件监听

    事件名事件描述
    onkeypress当某个键盘的键被按下(系统按钮如箭头键和 功能键无法得到识别)
    onkeydown当某个键盘的键被按下(系统按钮可以识别, 并且会先于onkeypress发生)
    onkeyup当某个键盘的键被松开
  • 常见的表单事件监听

    事件名事件描述
    onchange当用户改变域的内容
    onfocus当某元素获得焦点(比如tab键或鼠标点击)
    onblur当某元素失去焦点
    onsubmit当表单被提交
    onreset当表单被重置
    oninput当表单输入
  • 常见的页面事件监听

    事件名事件描述
    onload当页面或图像被完成加载
    onunload当用户退出页面

二、事件传播

  • 事件的传播是:先从外到内,然后再从内到外
    spread

  • onxxx写法和addEventListener()方法区别

    • onxxx写法只能监听冒泡阶段,DOM0级事件监听。
    • addEventListener(),通过参数控制,可以监听捕获或者冒泡,DOM2级事件监听。
  • 注意:

    • 最内部元素不再区分捕获和冒泡阶段,会先执行写在前面的监听,然后执行后写的监听。
    • 如果给元素设置相同的两个或多个同名事件,则DOM0级写法后面写的会覆盖先写的;而DOM2级会按顺序执行。

三、事件对象

  • 事件处理函数提供一个形式参数,它是一个对象,封装了本次事件的细节

  • 这个参数通常用单词event或字母e来表示。

      oBox.onmousemove = function (e) {
        // 对象e就是这次事件的"事件对象"
      }
    
  • 鼠标位置

    属性属性描述
    clientX鼠标指针相对于浏览器的水平坐标
    clientY鼠标指针相对于浏览器的垂直坐标
    pageX鼠标指针相对于整体网页的水平坐标
    pageY鼠标指针相对于整体网页的垂直坐标
    offsetX鼠标指针相对于事件源元素的水平坐标
    offsetY鼠标指针相对于事件源元素的垂直坐标

    offset
    client
    page

  • e.charCodee.keyCode属性

    • e.charCode属性通常用于onkeypress事件中,表示用户输入的字符的"字符码"。
    • e.keyCode属性通常用于onkeydowm事件中和onkeyup中,表示用户按下的按键的"键码"。
  • charCode字符码

    字符字符码
    数字0~数字948~57
    大写字母A~Z65~90
    小写字母a~z97~122
  • keyCode键码

    按键键码
    数字0~数字948~57
    字母不分大小a~z65~90
    四个方向键左、上、右、下37、38、39、40
    回车键13
    空格键32
  • e.preventDefault()方法

    • e.preventDefault()方法用来阻止事件产生的"默认动作"
  • e.stopPropagation()方法
    -e.stopPropagation()方法用来阻止事件继续传播

    • 一些场合,非常有必要切断事件继续传播,否则会造成页面特效显示bug。

四、事件委托

批量添加事件监听

题目:页面上一个无序列表<ul>,它内部共有20个<li>元素,请批量给它们添加点击事件监听,实现效果:点击哪个
<li>元素,哪个<li>元素就变红。

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <ul id="list">
        <li>列表项</li>
        <li>列表项</li>
        <li>列表项</li>
        <li>列表项</li>
        <li>列表项</li>
        <li>列表项</li>
        <li>列表项</li>
        <li>列表项</li>
        <li>列表项</li>
        <li>列表项</li>
        <li>列表项</li>
        <li>列表项</li>
        <li>列表项</li>
        <li>列表项</li>
        <li>列表项</li>
        <li>列表项</li>
        <li>列表项</li>
        <li>列表项</li>
        <li>列表项</li>
        <li>列表项</li>
    </ul>

    <script>
        var oList = document.getElementById('list');
        var lis = oList.getElementsByTagName('li');

        // 书写循环语句,批量给元素添加监听
        for (var i = 0; i < lis.length; i++) {
            lis[i].onclick = function () {
                // 在这个函数中,this表示点击的这个元素,this涉及函数上下文的相关知识,我们在“面向对象”课程中介绍
                this.style.color = 'red';
            };
        }
    </script>
</body>

</html>
  • 批量添加事件监听的性能问题

    • 每一个事件监听注册都会消耗一定的系统内存,而批量添 加事件会导致监听数量太多,内存消耗会非常大
    • 实际上,每个<li>的事件处理函数都是不同的函数,这些函数本身也会占用内存。
  • 新增元素动态绑定事件

    题目:页面上有一个无序列表<ul>,它内部没有<li>元素, 请制作一个按钮,点击这个按钮就能增加一个<li>元素。
    并且要求每个增加的<li>元素也要有点击事件监听,实现效果 点击哪个<li>元素,哪个<li>元素就变红

    <!DOCTYPE html>
    <html lang="en">
    
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
    </head>
    
    <body>
        <button id="btn">按我添加新的li列表项</button>
        <ul id="list"></ul>
    
        <script>
            var oBtn = document.getElementById('btn');
            var oList = document.getElementById('list');
            var lis = oList.getElementsByTagName('li');
    
            // 按钮的点击事件
            oBtn.onclick = function () {
                // 创建一个新的li列表项,孤儿节点
                var oLi = document.createElement('li');
                oLi.innerHTML = '我是列表项';
                // 上树
                oList.appendChild(oLi);
                // 给新创建的这个li节点添加onclick事件监听
                oLi.onclick = function () {
                    this.style.color = 'red';
                };
            };
        </script>
    </body>
    
    </html>
    
    • 动态绑定事件的问题
      • 新增元素必须分别添加事件监听,不能自动获取事件监听
      • 大量事件监听、大量事件处理函数会产生大量内存消耗
  • 事件委托

    • 利用事件冒泡机制,将后代元素事件委托给祖先元素

    • 事件委托通常需要结合使用e.target属性

      参数描述
      target触发此事件的最早元素,即"事件源元素"
      currentTarget事件处理程序附加到的元素
      <!DOCTYPE html>
      <html lang="en">
      
      <head>
          <meta charset="UTF-8">
          <meta name="viewport" content="width=device-width, initial-scale=1.0">
          <title>Document</title>
      </head>
      
      <body>
          <button id="btn">按我创建一个新列表项</button>
          <ul id="list">
              <li>列表项</li>
              <li>列表项</li>
              <li>列表项</li>
          </ul>
          <script>
              var oList = document.getElementById('list');
              var oBtn = document.getElementById('btn');
      
              oList.onclick = function (e) {
                  // e.target表示用户真正点击的那个元素
                  e.target.style.color = 'red';
              };
      
              oBtn.onclick = function () {
                  // 创建新的li元素
                  var oLi = document.createElement('li');
                  // 写内容
                  oLi.innerText = '我是新来的';
                  // 上树
                  oList.appendChild(oLi);
              };
          </script>
      </body>
      
      </html>
      
  • 事件委托的使用场景

    • 当有大量类似元素需要批量添加事件监听时,使用事件委 托可以减少内存开销。
    • 当有动态元素节点上树时,使用事件委托可以让新上树的 元素具有事件监听
  • 使用事件委托时需要注意的事项

    • onmouseenter和onmouseover都表示"鼠标进入",它们有什么区别呢?
      • onmouseenter不冒泡onmouseover冒泡
    • 使用事件委托时要注意:不能委托不冒泡的事件给祖先元素
    • 最内层元素不能再有额外的内层元素了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/876933.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

项目实战 — 博客系统② {项目构建}

目录 一、创建项目 二、添加数据库 三、设置配置文件相关信息 四、 添加前端页面 五、构建项目分层 六、编写基本类 一、创建项目 二、添加数据库 -- 创建数据库 drop database if exists cat_blog; create database cat_blog DEFAULT CHARACTER SET utf8mb4;-- 使用数…

这四种订货系统不能选(一):不能独立品牌

随着商业环境的日益竞争和客户需求的不断变化&#xff0c;订货系统正逐渐成为企业管理中不可或缺的一部分。不少企业在订货系统的选择上不知从哪入手&#xff0c;今天我分享哪四种订货系统不能选。大家点个关注点个赞&#xff0c;我们接着往下看。 一、不能独立品牌的订货系统不…

C语言学习笔记---数据的存储详解

C语言程序设计笔记---015 C语言数据的存储1、数据类型的意义1.1、unsigned与signed数据类型例程11.2、补码与原码相互转换例程2 2、大小端的介绍2.1、大小端的例程12.2、大小端的例程2 --- 判断当前编译器环境属于大端或小端 3、综合练习题探究数据的存储3.1、练习题13.2、练习…

Qt 杂项(Qwt、样式等)

Qt隐藏窗口边框 this->setWindowFlags(Qt::FramelessWindowHint);Qt模态框 this->setWindowModality(Qt::ApplicationModal);QLable隐藏border 代码中设置 lable->setStyleSheet("border:0px");或者UI中直接设置样式&#xff1a;“border:0px” Qwt开源…

vue3 使用@vue-office/excel预览本地excel文件 demo

vue3 使用vue-office/excel预览excel文件 demo 显示如下&#xff1a; npm地址&#xff1a;https://www.npmjs.com/package/vue-office/excel vue-office还有pdf和docx&#xff0c;按需下载对应插件 npm install vue-office/excel vue-demivue代码如下 app.vue <templ…

2.Model、ModelMap和ModelAndView的使用详解

1.前言 最近SSM框架开发web项目&#xff0c;用得比较火热。spring-MVC肯定用过&#xff0c;在请求处理方法可出现和返回的参数类型中&#xff0c;最重要就是Model和ModelAndView了&#xff0c;对于MVC框架&#xff0c;控制器Controller执行业务逻辑&#xff0c;用于产生模型数据…

腾讯云国际站代充-阿里云ECS怎么一键迁移到腾讯云cvm?

今天主要来介绍一下如何通过阿里云国际ECS控制台一键迁移至腾讯云国际CVM。腾讯云国际站云服务器CVM提供全面广泛的服务内容。无-需-绑-定PayPal&#xff0c;代-充-值腾讯云国际站、阿里云国际站、AWS亚马逊云、GCP谷歌云&#xff0c;官方授权经销商&#xff01;靠谱&#xff0…

嵌入式Qt开发—Excel表格数据导出

有一个嵌入式Excel表格数据导出的需求&#xff1a;应用软件运行于嵌入式Linux平台上&#xff0c;在设备运行过程中&#xff0c;存储了许多数据&#xff0c;这些数据想以表格的形式导出。考虑到Windows平台的普遍性&#xff0c;需要将数据以excel表格形式导出&#xff0c;故选择…

基于机器学习的假新闻检测 -- 机器学习项目基础篇(14)

不同平台上的假新闻正在广泛传播&#xff0c;这是一个令人严重关切的问题&#xff0c;因为它导致社会稳定和人们之间建立的纽带的永久破裂。很多研究已经开始关注假新闻的分类。 在这里&#xff0c;我们将尝试在Python中的机器学习的帮助下解决这个问题。 主要步骤 导入库和数…

一生一芯4——使用星火应用商店在ubuntu下载QQ、微信、百度网盘

星火应用商店可以非常方便的完成一些应用的下载&#xff0c;下面是官方网址 http://spark-app.store/download 我使用的是intel处理器&#xff0c;无需下载依赖项&#xff0c;直接点击软件本体 我这里下载amd64,根据自己的处理器下载对应版本 sudo apt install ./spark-stor…

影响股票数据接口l2传输数据快慢因素有哪些?(l2数据接口)

股票数据接口l2是一种用于获取股票市场相关数据的编程接口。它允许开发者通过编程的方式获取、查询、订阅和更新股票相关数据&#xff0c;如股票价格、成交量、财务数据等&#xff0c;并将这些数据用于自己的应用或系统中。l2数据接口通常提供实时行情数据、历史行情数据、财务…

如何批量替换文件名称的一部分?

如何批量替换文件名称的一部分&#xff1f;在工作和生活中&#xff0c;我们经常需要对一些文件和文件夹进行批量修改操作&#xff0c;其中最常见的是对文件名进行部分更改&#xff0c;例如批量替换文件名中的一部分分子。这些操作不仅可以提高工作效率&#xff0c;还能帮助我们…

elementUI 的上传组件<el-upload>,自定义上传按钮样式

方法一&#xff1a; 原理&#xff1a;调用<el-upload>组件的方法唤起选择文件事件 效果&#xff1a; 页面代码&#xff1a; 1、选择图片按钮 <div class"flex_row_spacebetween btn" click"chooseImg"><span class"el-icon-plus ic…

Boost开发指南-4.4assign

assign 许多情况下我们都需要为容器初始化或者赋值&#xff0c;填入大量的数据&#xff0c;比如初始错误代码和错误信息&#xff0c;或者是一些测试用的数据。在C98中标准容器仅提供了容纳这些数据的方法&#xff0c;但填充的步骤却是相当地麻烦&#xff0c;必须重复调用inser…

财报解读:继续押注Disney+,迪士尼距离盈利还有多远?

迪士尼最新一季的“答卷”&#xff0c;透露着不小的寒气。 近日&#xff0c;迪士尼披露了2023财年第三季度&#xff08;自然年2023年Q2&#xff09;业绩报告&#xff0c;营收223.3亿美元&#xff0c;同比仅增长4%&#xff0c;低于市场预期的225.1亿美元&#xff1b;归母净亏损…

Python第三方库 - Pandas库

文章目录 1. Pandas介绍2. Pandas基础2.1 引入2.2 数据结构2.2.1 Series2.3 DataFrame2.3.1 概念 3 Pandas CSV 文件3.1 语法3.2 遇到的问题 参考文档 1. Pandas介绍 概念: Pandas 是 Python 的核心数据分析支持库&#xff0c;提供了快速、灵活、明确的数据结构&#xff0c;旨…

【Vue-Router】重定向

First.vue <template><h1>First Seciton</h1> </template>Second.vue&#xff0c;Third.vue代码同理 UserSettings.vue <template><h1>UserSettings</h1><router-link to"/settings/children1">children1</ro…

41、可靠传输——停等ARQ

前面两节内容我们学习了传输层的基本概况的一些知识&#xff0c;包括传输层在TCP/IP协议栈中负责的任务、传输层的两大协议&#xff0c;以及端口号、套接字等一些基本的概念。从这一节开始&#xff0c;我们将开启两大协议中TCP协议的学习。 但是&#xff0c;经过之前的学习&am…

企望制造ERP系统 RCE漏洞复现(HW0day)

0x01 产品简介 企望制造纸箱业erp系统由深知纸箱行业特点和业务流程的多位IT专家打造&#xff0c;具有国际先进的管理方式&#xff0c;将现代化的管理方式融入erp软件中&#xff0c;让企业分分钟就拥有科学的管理经验。 erp的功能包括成本核算、报价定价、订单下达、生产下单、…

上传excel文件

文件上传&#xff0c;其实就是用el-upload组件来实现上传&#xff0c;只是换了样式&#xff0c;和图片上传一样 <el-form-item label"选择文件"><el-input placeholder"请选择文件" v-model"form.file" disabled style"width: 45…