JavaScript---DOM---高级事件---1.8

news2025/1/10 20:29:19

注册事件(绑定事件)

给元素添加事件称为注册事件或绑定事件。注册事件有两种方式:传统方式、方法监听注册方式。

传统注册方式:

利用on开头的事件onclick

<button onclick="alert(hi~)"></button> 
btn.onclick = function() {}

特点:注册事件的唯一性。同一个元素同一个事件只能设置一个处理函数,最后注册的处理函数将会覆盖前面注册的处理函数。

方法监听注册方式:

addEventListener(): w3c标准  推荐方式
(IE9之前的IE不支持此方法,可使用attachEvent()代替)

btns[1].addEventListener('click',function(){
})

eventTarget.addEventListener(type,listener[,useCapture])
//eventTarget.addEventListener()方法将指定的监听器注册到eventTarget(目标对象)上,当该对象触发指定的事件时,就会执行事件处理函数。

该方法接收三个参数:

  • type:事件类型是字符串,比如click、mouseover,注意这里不要带on
  • listener:事件处理函数,事件发生时,会调用该监听函数
  • useCapture:可选参数,是一个布尔值(默认false)。学完DOM事件流后再进一步学习

特点:同一个元素同一个事件可以注册多个监听器,按注册顺序依次执行。

删除事件(解绑事件)

传统注册方式:

eventTarget.onclick = null;

<div>1</div>
<script>
    var divs = document.querySelectorAll('div');
    divs[0].onclick = function() {
        alert(11);
        divs[0].onclick = null;
</script>

方法监听注册方式:

eventTarget.removeEventListener(type,listener [,useCapture]);

<div>1</div>
<script>
    divs[0].addEventListener('click',fn);// 里面的fn 不需要调用加小括号
    function fn() {
        alert(22);
        divs[0].removeEventListener('click',fn);
    }
</script>

DOM事件流

事件流描述的是从页面中接收事件的顺序。
事件发生时会在元素节点之间按照特定的顺序传播,这个传播过程即DOM事件流

比如我们给一个div注册了点击事件,DOM事件流分为3个阶段:

  • 捕获阶段:网景最早提出,由DOM最顶层节点开始,逐级向下传播到最具体的元素接收的过程。
  • 当前目标阶段
  • 冒泡阶段:IE最早提出,事件开始时由最具体的元素接收,逐级向上传播到DOM最顶层节点的过程。

        

注意

  • JS代码中只能执行捕获或冒泡其中的一个阶段。
  • onclick和attachEvent只能得到冒泡阶段。
  • addEventListener(type,listener[,useCapture])第三个参数如果是true,表示在事件捕获阶段调用事件处理程序;如果是false(不写就默认false),表示在事件冒泡阶段调用事件处理程序。
  • 实际开发中我们很少使用事件捕获,我们更关注事件冒泡
  • 有些事件是没有冒泡的,比如onblur、onfocus、onmouseenter、onmouseleave

事件对象

什么是事件对象

  • 官方解释:event对象代表事件的状态,比如键盘按键的状态、鼠标的位置、鼠标按钮的状态。event就是一个事件对象,写到我们侦听函数的小括号里面,当形参来看。
  • 简单理解:事件发生后,跟事件相关的一系列信息数据的集合都放到这个对象里面,这个对象就是事件对象event,它有很多属性和方法。
  • 事件对象只有有了事件才会存在,它是系统给我们自动创建的,不需要我们传递参数。
  • 这个事件对象可以自己命名,比如event、evt、e等等。
<div>123</div>
<script>
    var div = document.querySelector('div');
    // 传统方式
    // div.onclick = function(event) {
    //     console.log(event);
    // }
    // 事件监听方法
    div.addEventListener('click', function(event){
        console.log(event);
    })
</script>

事件对象的常见属性和方法

var div = document.querySelector('div');
div.addEventListener('click',function(e) {
    console.log(e.target);
    //e.target返回的是触发事件的对象(元素)
    //this返回的是绑定事件的对象(元素)
    //区别:e.target点击了哪个元素,就返回那个元素
    //this哪个元素绑定了这个点击事件,那么就返回谁
}
<a href="https://www.baidu.com/">百度</a>
<script>
    var a = document.querySelector('a');
    a.addEventListener('click', function(e){
        e.preventDefault();
    })
    a.onclick = function(e) {
        e.preventDefault();
        // return false;//return 后面的代码不会执行,只限于传统注册方式
    }
</script>

阻止事件冒泡

阻止事件冒泡的两种方式

事件冒泡:开始时由最具体的元素接收,然后逐级向上传播到DOM最顶层节点。事件冒泡本身的特性会带来坏处,也会带来好处,需要我们灵活掌握。

标准写法:利用事件对象里面的stopPropagation()方法。

<div class="father">
    <div class="son">son</div>
</div>
<script>
    var son = document.querySelector('.son');
    son.addEventListener('click',function(e) {
        alert('son');
        e.stopPropagation();
    },false);
    var father = document.querySelector('.father');
    father.addEventListener('click',function() {
        alert('father');
    },false);
    document.addEventListener('click',function() {
        alert('document');
    })
</script>

事件委托(代理、委派)

事件冒泡本身的特性会带来坏处,也会带来好处,需要我们灵活掌握。程序中也有如此场景:

点击每个li都会弹出对话框:以前需要给每个li注册事件,是非常辛苦的,
而且访问DOM的次数越多,这就会延长整个页面的交互就绪时间。
<ul>
    <li>知否知否,应该有弹框在手</li>
    <li>知否知否,应该有弹框在手</li>
    <li>知否知否,应该有弹框在手</li>
    <li>知否知否,应该有弹框在手</li>
    <li>知否知否,应该有弹框在手</li>
</ul>

事件委托:也称事件代理,在jQuery里称为事件委派。

事件委托的原理

不是每个子节点单独设置事件监听器,而是事件监听器设置在其父节点上,然后利用冒泡原理影响设置每个子节点。

以上案例:给ul注册点击事件,然后利用事件对象的target来找到当前点击的li,因为点击li,事件会冒泡到ul上,ul有注册事件,就会触发事件监听器。

<script>
    var ul = document.querySelector('ul');
    ul.addEventListener('click',function(e) {
        // alert('知否知否,应该有弹框在手');
        e.target.style.backgroundColor = 'pink';
    })
</script>

事件委托的作用

我们只操作了一次DOM,提高了程序的性能

常用的鼠标事件

禁止鼠标右键菜单

contextmenu主要控制应该何时显示上下文菜单,主要用于程序员取消默认的上下文菜单。

document.addEventListener('contextmenu',function(e) {
    e.preventDefault();
})

禁止鼠标选中(selectstart开始选中)

document.addEventListener('selectstart',function(e) {
    e.preventDefault();
})

鼠标事件对象

event对象代表事件的状态,跟事件相关的一系列信息的集合。现阶段我们主要是用鼠标事件对象MouseEvent和键盘事件对象KeyboardEvent 。

<style>
    body {height: 2000px;}
</style>
<script>
    // 鼠标事件对象 MouseEvent
    document.addEventListener('click',function(e) {
        // 1.client 鼠标在可视区的x和y坐标
        console.log(e.clientX);
        console.log(e.clientY);
        // 2.page 鼠标在页面 文档的x和y坐标
        console.log(e.pageX);
        console.log(e.pageY);
        // 3.screen 鼠标在电脑屏幕的×和y坐标
        console.log(e.screenX);
        console.log(e.screenY);
    });
</script>

案例:跟随鼠标移动的小天使

  • 鼠标不断的移动,使用鼠标移动事件:mousemove。
  • 在页面中移动,给document注册事件。
  • 图片要移动距离,而目不占位置,使用绝对定位即可。
  • 核心原理:每次鼠标移动,都会获得最新的鼠标坐标,把这个x和y坐标做为图片的top和left值就可以移动图片。
<style>
    img { width: 100px; height: 80px; position: absolute; }
</style>

<img src="images/angle.gif" alt="">
<script>
    var pic = document.querySelector('img');
    // mousemove只要我们鼠标移动 1px 就会触发这个事件
    document.addEventListener('mousemove',function(e) {
        var x = e.pageX;
        var y = e.pageY;
        console.log('x坐标是'+ x,'y坐标是'+ y);
        // 千万不要忘记给left和top添加 px单位
        pic.style.left = x - 50 + 'px';
        pic.style.top = y - 40 + 'px';
        // pic.style.cursor = 'none';
    }); 
</script>

 

常用的键盘事件

<script>
    // document.onkeyup = function() {
    //     alert('我弹起来了~');
    // }
    document.addEventListener('keyup',function() {
        console.log('我弹起来了~');
    })
    document.addEventListener('keydown',function() {
        console.log('我按下了down~');
    })
    document.addEventListener('keypress',function() {
        console.log('我按下了press~');
    })
</script>

注意:

  • 如果使用addEventListener不需要加on。
  • 三个事件的执行顺序是:keydown - keypress - keyup

keyCode属性

注意:

  • onkeydownonkeyup不区分字母大小写,onkeypress区分字母大小写。
  • 在实际开发中,我们更多使用keydownkeyup,它能识别所有的键(包括功能键)。
  • Keypress不识别功能键,但是keyCode属性能区分大小写,返回不同的ASCII值。
<script>
    // 键盘事件对象中的keyCode属性可以得到相应键的ASCII码值
    document.addEventListener('keyup', function(e) {
        console.log('up' + e.keyCode);
        //我们可以利用keycode返回的ASCII码值来判断用户按下了那个键
        if (e.keyCode === 65) {
            alert('您按下的a键');
        } else {
            alert('您没有按下a键');
        }
    });
    document.addEventListener('keypress', function(e) {
        console.log('press' + e.keyCode);
    })
</script>

案例:模拟京东按键输入内容

  • 核心思路:检测用户是否按下了s键,如果按下s键,就把光标定位到搜索框里面。
  • 使用键盘事件对象里面的keyCode判断用户按下的是否是s键
  • 搜索框获得焦点:使用js里面的focus()方法。
<input type="text">
<script>
    var search = document.querySelector('input');
    document.addEventListener('keyup', function(e) {
        if(e.keyCode === 83) {  // 也可以用if(e.key === 's') 
            search.focus();
        }
    });
</script>

案例:模拟京东快递单号查询

当我们在文本框中输入内容时,文本框上面自动显示大字号的内容。

  • 快递单号输入内容时,上面的大号字体盒子(con)显示(这里面的字号更大)。
  • 表单检测用户输入:给表单添加键盘事件。
  • 同时把快递单号里面的值(value)获取过来赋值给con盒子(innerText)做为内容。
  • 如果快递单号里面内容为空,则隐藏大号字体盒子(con)盒子。
  • keydownkeypress在文本框内的特点:事件触发时,文字还没有落入文本框中。
  • keyup事件触发时,文字已经落入文本框中。
  • 当我们失去焦点,就隐藏这个con盒子
  • 当我们获得焦点,并且文本框内容不为空,就显示这个con盒子
<style>
    * {padding: 0;margin: 0;}
    .search {position: relative;width: 178px;margin: 100px;}
    .con {display: none;position:absolute;top:-40px;width:171px;
          border:1px solid rgba(0,0,0,.2);
          box-shadow:0 2px 4px rgba(0,0,0,.2);
          padding:5px 0;font-size:18px;line-height:20px;color:#333;
    }
    .con::before {content:'';width:0;height:0;position:absolute;
          top:28px;left:18px;border:8px solid #000;
          border-style:solid dashed dashed;
          border-color:#fff transparent transparent;
    }
</style>

<div class="search">
    <div class="con">123</div>
    <input type="text" class="jd" placeholder="请输入您的快递单号">
</div>
<script>
    var con = document.querySelector('.con');
    var jd_input = document.querySelector('.jd');
    jd_input.addEventListener('keyup', function() {
        if(this.value == '') {
            con.style.display = 'none';
        } else {
            con.style.display = 'block';
            con.innerText = this.value;
        }
    })
    jd_input.addEventListener('blur',function() {
        con.style.display = 'none';
    })
    jd_input.addEventListener('focus',function() {
        if(this.value !== '') {
            con.style.display = 'block';
        }
    })
</script>

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

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

相关文章

测试用例具体的设计方法

等价类法由于输入的集合是无穷的&#xff0c;不能全部覆盖到&#xff0c;所以通过划分若干个等价类&#xff0c;选出有代表性的达到尽量多的功能覆盖有效等价类&#xff1a;根据规格说明书是合理的、有意义的输入数据构成的集合无效等价类&#xff1a;根据需求说明书是不合理&a…

246页10万字省级政务专用云项目技术方案

【版权声明】本资料来源网络&#xff0c;知识分享&#xff0c;仅供个人学习&#xff0c;请勿商用。【侵删致歉】如有侵权请联系小编&#xff0c;将在收到信息后第一时间删除&#xff01;完整资料领取见文末&#xff0c;部分资料内容&#xff1a; 目录 对本项目的技术服务类总体…

【Java AWT 图形界面编程】LayoutManager 布局管理器 ⑦ ( Box 容器 | Box 容器中添加分割 )

文章目录一、Box 容器二、Box 容器 API三、Box 容器代码示例四、Box 容器中添加分割一、Box 容器 为了 方便使用 BoxLayout 布局 , Swing 中提供了 Box 容器 ; Box 容器 默认的 布局管理器 就是 BoxLayout ; 通过在 Box 容器构造函数中传入不同的参数 , 可以直接创建 水平排列…

Java基础语法(一)

注释1.1注释概述注释是在程序指定位置添加的说明性信息注释不参与程序运行&#xff0c;仅起到说明作用1.2注释分类单行注释格式&#xff1a;//注释信息多行注释格式&#xff1a;/*注释信息*/文档注释格式&#xff1a;/**注释信息*/文档注释目前用不上&#xff0c;暂不讲解/* Ja…

C++入门

目录 1. 命名空间 1.1 命名空间的定义 1.2 命名空间的使用 2. C的输入输出 3. 缺省参数 3.1 缺省参数概念 3.2 缺省参数分类 4.函数重载 4.1 函数重载概念 4.2 C支持函数重载的原理——名字修饰 5. 引用 5.1 引用概念 5.2 引用特性 5.3 常引用 5.4 使用场景 5.5 引用…

什么是测试金字塔?如何使用测试金字塔来构建自动化测试体系?

测试金字塔 &#xff08;Test Pyramid&#xff09;是一套使用单元测试&#xff0c;集成测试和端到端测试来构建自动化测试体系的方法。 如下图所示&#xff0c;在金字塔的最下方是单元测试&#xff0c;中段是集成测试&#xff0c;最上方是端到端测试。单元测试实现的成本最低&…

Android 深入系统完全讲解(17)

这个就是我们在初始化的时候给对应的属性设置上下文。chcon 这个可以修改上下文。 我们在遇见类似的属性读取不到的时候&#xff0c;一般操作是&#xff1a; getprop -z 看下属性的上下文&#xff0c;然后 ps -z 看下进程的上下文&#xff0c;然后判断出来是否有对应的 权限&am…

1. PyTorch是什么?

这篇博客将介绍PyTorch深度学习库&#xff0c;包括&#xff1a; PyTorch是什么如何安装PyTorch重要的PyTorch功能&#xff0c;包括张量和自动标记PyTorch如何支持GPU为什么PyTorch在研究人员中如此受欢迎PyTorch是否优于Keras/TensorFlow是否应该在项目中使用PyTorch或Keras/T…

ArcGIS10.2保姆式安装教程,超详细;附安装包

安装前请关闭杀毒软件&#xff0c;系统防火墙&#xff0c;断开网络连接 参考链接&#xff1a;请点击 下载链接&#xff1a; 通过百度网盘分享的文件&#xff1a;ArcGIS10.2zip 链接:https://pan.baidu.com/s/1s_xc1HvmMdo4fnnUo97ldA 提取码:v74k 复制这段内容打开「百度网盘A…

2022年11月下午案例分析真题及答案解析

试题一&#xff08;共15分&#xff09;&#xff08;202211&#xff09; 阅读下列说明和图&#xff0c;回答问题1至问题4&#xff0c;将解答填入答题纸的对应栏内。 【说明】 随着新能源车数量的迅猛增长&#xff0c;全国各地电动汽车配套充电桩急速增长&#xff0c;同时也带…

2023年网络安全比赛--Linux系统渗透提权中职组(超详细)

一、竞赛时间 180分钟 共计3小时 二、竞赛阶段 竞赛阶段 任务阶段 竞赛任务 竞赛时间 分值 1.使用渗透机对服务器信息收集,并将服务器中SSH服务端口号作为flag提交; 2.使用渗透机对服务器信息收集,并将服务器中主机名称作为flag提交; 3.使用渗透机对服务器信息收集,并将服…

数据科学家必备的 3 个 Jupyter Notebook 扩展

如果您是数据科学家、机器学习工程师或任何其他类型的数据专业人员&#xff0c;您可能已经花了很多时间使用 Jupyter 笔记本。虽然 Jupyter notebooks 已经是一个强大的工具&#xff0c;但还有许多扩展可以进一步增强您的体验。 在本文中&#xff0c;我们将向您介绍三个最有用…

活动星投票创心服务网络评选微信的投票方式线上免费投票

“创心服务”网络评选投票_视频投票评选小程序_线实时投票小程序_微信投票链接创建现来说&#xff0c;公司、企业、学校更多地想借助短视频推广自己。通过微信投票小程序&#xff0c;网友们就可以通过手机拍视频上传视频参加活动&#xff0c;而短视频微信投票评选活动既可以给用…

表单验证的简单实现

表单验证一. 作用二. 需求三. 实现需求一&#xff1a;HTML&#xff1a;JavaScript&#xff1a;需求二&#xff1a;JavaScript&#xff1a;一. 作用 如果没有表单验证&#xff0c;错误的数据就会发往服务端&#xff0c;会造成服务端压力过大&#xff1b; 所以在前端对数据进行过…

ArcGIS基础实验操作100例--实验98计算上游集水区污染值

本实验专栏参考自汤国安教授《地理信息系统基础实验操作100例》一书 实验平台&#xff1a;ArcGIS 10.6 实验数据&#xff1a;请访问实验1&#xff08;传送门&#xff09; 空间分析篇--实验98 计算上游集水区污染值 目录 一、实验背景 二、实验数据 三、实验步骤 &#xff0…

【阶段三】Python机器学习28篇:机器学习项目实战:KMeans算法的基本原理与KMeans聚类分群模型

本篇的思维导图: KMeans模型 KMeans算法的基本原理 KMeans算法名称中的K代表类别数量,Means代表每个类别内样本的均值,所以KMeans算法又称为K-均值算法。KMeans算法以距离作为样本间相似度的度量标准,将距离相近的样本分配至同一个类别。样本间距离的计算方式可以是…

QListWidget 自定义 item的图标和文字的位置

目录前言思路一思路二思路二缺陷思路三思路四前言 楼主并没有完整的解决这个问题&#xff0c;如果你是着急寻找解决方案的就可以划走了&#xff0c;如果你对楼主的解决思路有兴趣&#xff0c;那么可以继续向下阅读。首先需求是可以控制QListWidgetItem的icon和text x轴的位置&…

【树】树、二叉树的基础知识

树定义&#xff1a;树是n&#xff08;n≥0&#xff09;个结点的有限集合T。当n0时&#xff0c;称为空树&#xff1b;当n>0时&#xff0c;该集合满足如下条件&#xff1a; (1) 其中必有一个称为根&#xff08;root&#xff09;的特定结点&#xff0c;它没有直接前驱&#xff…

基于javaweb jsp+servlet学生宿舍管理系统

基于javaweb jspservlet学生宿舍管理系统 博主介绍&#xff1a;5年java开发经验&#xff0c;专注Java开发、定制、远程、文档编写指导等,csdn特邀作者、专注于Java技术领域 作者主页 超级帅帅吴 Java毕设项目精品实战案例《500套》 欢迎点赞 收藏 ⭐留言 文末获取源码联系方式 …

Mysql入门技能树-时间日期函数(一)-练习篇

DAY Joe 需要从日期中提取当天是几号&#xff0c;下列哪些函数可以实现这个功能&#xff1f; 1.DAY 2.DAYOFMONTH 3.DAYOFYEAR 4.TO_DAYS 答案是&#xff1a;C SELECT DAY(2023-02-14)SELECT DAYOFMONTH(2023-02-14)结果都是14 -- 返回 d 是一年中的第几天&#xff0c;范围…