WebAPIs 第二天
DOM事件基础
- 事件监听
- 事件类型
- 事件对象
一.事件监听
① 概念:就是让程序检测是否有事件发生,一旦有事件触发,就立即调用一个函数做出响应,也成为绑定事件或者注册事件
② 语法:元素对象.addEventListener('事件类型', 要执行的函数)
③ 事件监听三要素:
(1)事件源:哪个DOM元素被事件触发了,要获取dom元素
(2)事件类型:用什么方式触发,比如鼠标单击click, 鼠标经过 mouseover等
(3)事件调用的函数:要做什么事
④ 注意:
- 事件类型要加引号
- 函数是触发一次就执行一次
const btn = document.querySelector('button')btn.addEventListener('click', function() {alert('你好呀')
})
⑤ 事件监听版本(拓展)
-
DOM L0
事件源.on事件 = function(){}
-
DOM L2
事件源.addEventListenner(事件,事件处理函数)
- 区别
on 方式会被覆盖,addEventListenner 方式可绑定多次,拥有事件更多特性,推荐使用
二.事件类型
① 鼠标事件:鼠标触发
- click 鼠标点击
- mouseenter 鼠标经过
- mouseleave 鼠标离开
const div = document.querySelector('div')
// 鼠标经过
div.addEventListener('mouseenter', function () {console.log('hello')
})
// 鼠标离开
div.addEventListener('mouseleave', function () {console.log('走了')
})
② 焦点事件:表单获得光标
- focus 获得焦点
- blur 失去焦点
// 获得焦点和失去焦点
const input = document.querySelector('input')
input.addEventListener('focus', function () {console.log('获得焦点')
})input.addEventListener('blur', function () {console.log('失去焦点')
})
③ 键盘事件:键盘触发
- keydown 键盘按下触发
- keyup 键盘抬起触发
const input = document.querySelector('input')
input.addEventListener('keydown', function () {console.log('键盘按下')
})
input.addEventListener('keyup', function () {console.log('键盘弹起')
})
④ 文本事件:表单输入触发
- input 用户输入事件
const input = document.querySelector('input')
input.addEventListener('input', function () {console.log(input.value)
})
三.事件对象
1.获取事件对象
2.事件对象常用属性
3.1 获取事件对象
① 事件对象概念
- 也是个对象,这个对象有事件触发时的相关信息
② 使用场景
- 可以判断用户按下哪个键或者点击了哪个元素
③ 如何获取
- 在事件绑定的回调函数的第一个参数就是事件对象
- 一般命名为event,ev, e
④ 语法
元素.addEventListener('click', function(e) {
})
3.2 事件对象属性
- type 获取当前的事件类型
- clientX/clientY 获取光标相对于浏览器可见窗口左上角的位置
- offsetX/offsetY 获取光标相对于DOM元素左上角的位置
- key 用户按下的键盘键的值(不推荐)
四.环境对象
- 环境对象:指的是函数内部特殊的变量this,代表当前函数运行时所处的环境
- 作用:弄清楚this的指向,可以使代码更加简洁
- 函数的调用方式不同,this指代的对象也不同
- 【粗略规则】谁调用this就指向谁
五.回调函数
① 概念:如果将函数A作为参数传递给函数B时,将函数A称为回调函数
② 使用匿名函数作为回调函数比较常见
相关文章:
WebAPIs 第二天
DOM事件基础 事件监听事件类型事件对象 一.事件监听 ① 概念:就是让程序检测是否有事件发生,一旦有事件触发,就立即调用一个函数做出响应,也成为绑定事件或者注册事件 ② 语法:元素对象.addEventListener(事件类型&…...
解决macOS执行fastboot找不到设备的问题
背景 最近准备给我的备用机Redmi Note 11 5G刷个类原生的三方ROM,MIUI实在是用腻了。搜罗了一番,在XDA上找到了一个基于Pixel Experience开发的ROM:PixelExperience Plus for Redmi Note 11T/11S 5G/11 5G/POCO M4 Pro 5G (everpal)…...
Linux命令 -- chmod
Linux命令 -- chmod 参数含义权限说明修改文件权限修改目录权限 参数含义 文件用户 u 文件所有者g 文件所有者同组的用户o 其它用户a 所有用户 文件权限 r 读权限(对应数值4)w 写权限(对应数值2)x 执行权限(对应数…...
国产超低功耗32位MCU的应用
随着物联网技术的不断发展,超低功耗MCU已经成为了物联网方案中主要的芯片处理技术。超低功耗MCU具有众多的优点,其中一大所用就是能够大大提高物联网设备的续航能力,保证设备在长时间内不掉电不断电。那么,超低功耗MCU在物联网方案…...
将数组(矩阵)旋转根据指定的旋转角度scipy库的rotate方法
【小白从小学Python、C、Java】 【计算机等考500强证书考研】 【Python-数据分析】 将数组(矩阵)旋转 根据指定的旋转角度 scipy库的rotate方法 关于下列代码说法正确的是? import numpy as np from scipy.ndimage import rotate a np.array([[1,2,3,4], …...
MFC创建和使用OCX控件
文章目录 MFC建立OCX控件注册OCX控件与反注册使用Internet Explorer测试ocx控件OCX控件添加方法OCX控件添加事件Web使用OCX控件MFC使用OCX控件使用OCX控件调用ocx的功能函数对ocx的事件响应OCX控件调试工具tstcon32.exe加载ocx控件使用tstcon32.exe调试ocxMFC建立OCX控件 新建…...
【设计模式】抽象工厂模式
抽象工厂模式(Abstract Factory Pattern)是围绕一个超级工厂创建其他工厂。该超级工厂又称为其他工厂的工厂。这种类型的设计模式属于创建型模式,它提供了一种创建对象的最佳方式。 在抽象工厂模式中,接口是负责创建一个相关对象…...
小白带你学习linux的Redis3.2集群(三十三)
目录 一、Redis主从复制 1、概念 2、作用 3、缺点 4、流程 5、搭建 6、验证 二、Reids哨兵模式 1、概念 2、作用 3、缺点 4、结构 5、搭建 6、验证 三、Redis集群 1、概述 2、原理 3、架构细节 4、选举过程 四、搭建 1、第一步现在外部使用finalshell 9.9…...
嵌入式技术,就在你的手边!
嵌入式技术,听起来多么高大上的名词,同时它也确实是当今信息技术的前沿领域,但这并不意味着它就距离我们很遥远。 事实恰恰相反,在当今科技发展迅猛的时代,嵌入式技术成为了人们生活中不可或缺的一部分。它以其小巧、高…...
nodejs+vue+elementui健康饮食美食菜谱分享网站系统
本系统采用了nodejs语言的vue框架,数据采用MySQL数据库进行存储。结合B/S结构进行开发设计,功能强大,界面化操作便于上手。本系统具有良好的易用性和安全性,系统功能齐全,可以满足饮食分享管理的相关工作。 语言 node.…...
input 设置type=“number“,鼠标悬停关闭提示语
一、问题 最近刚发现input 设置type"number"之后,鼠标悬停会出现提示语:请输入有效值。两个最接近的有效值分别为xx和xx。想要输入的值确实为number格式,又可以输入小数,不限制小数位,所以要把这讨厌的提示去…...
CSDN互利共赢玩法实战!!!
csdn项目第一波基本都顺利跑了起来,我们总计找来了一两千个新的项目源码,来让大家变现。 在实战中,主要两个玩法,一个引流,一个付费资源。付费资源门槛越来越高,所以我们这一波升级完成的号,就非…...
java.sql.SQLFeatureNotSupportedException 问题及可能的解决方法
目录 问题 分析: 解决方法 问题 java.sql.SQLFeatureNotSupportedException 分析: 可能是你的 druid的maven依赖版本太低了,我的以前是1.1.16,就出现了异常! 解决方法 把druid的maven依赖版本调高! 运…...
如何在 .NET Core WebApi 中处理 MultipartFormDataContent 中的文件
问题描述# 上图示例展示了用户通过 IOS 客户端发送请求时,对应后端接口接收到的 Request 内容。从请求内容的整体结果,我们可以看出这是一个 multipart/form-data 的数据格式,由于这种数据是由多个 multipart section 组成,所以我…...
【智力悬疑题】——【“找凶手”解法】
“找凶手”题目解法 “案件题目”💻 某地发生了一起凶杀案,警察通过排查确定杀人凶手必为4个嫌疑犯中的一个。以下为4个嫌疑犯的供词: A说:不是我。 B说:是C。 C说:是D。 D说:C在胡说。 已知3个…...
【论文阅读】基于深度学习的时序异常检测——TimesNet
系列文章链接 参考数据集讲解:数据基础:多维时序数据集简介 论文一:2022 Anomaly Transformer:异常分数预测 论文二:2022 TransAD:异常分数预测 论文三:2023 TimesNet:基于卷积的多任…...
P3741 honoka的键盘
题目背景 honoka 有一个只有两个键的键盘。 题目描述 一天,她打出了一个只有这两个字符的字符串。当这个字符串里含有 VK 这个字符串的时候,honoka 就特别喜欢这个字符串。所以,她想改变至多一个字符(或者不做任何改变…...
编写第一个 React Native 程序
React Native 目录 使用React Native CLI命令创建的目录如下图所示: 重要目录说明 目录说明__tests__存放测试用例的目录.bundle / config配置文件(一般不会用到)android 和 IOS 文件夹这两个文件夹主要是存放安卓和 ios 相关的配置文件和…...
AI:03-基于深度神经网络的低空无人机目标检测图像识别的研究
文章目录 数据集收集与预处理深度神经网络模型设计模型训练与优化目标检测与图像识别代码实现:实验结果与分析讨论与展望低空无人机的广泛应用为许多领域带来了巨大的潜力和机会。为了实现无人机的自主导航和任务执行,准确的目标检测和图像识别是至关重要的。本文旨在研究并提…...
Arcgis将一个shp依照属性表导出为多个shp
# -*- coding:utf-8 -*-import arcpy import osfrom arcpy import env#env.workspace "./" #自己设置路径shp rC:\Users\Administrator\Desktop\Lake\xxx.shp #shp文件路径outpath r"C:\Users\Administrator\Desktop\Lake\fenli" #输出结果路径with arc…...
基于Python的课表管理系统毕设
博主介绍:✌ 专注于Java,python,✌关注✌私信我✌具体的问题,我会尽力帮助你。一、研究目的本研究旨在开发一套基于Python的课表管理系统,以实现课程信息的自动化管理、优化教学资源配置和提高教学效率。具体研究目的如下:实现课程…...
代码生成准确率从68%跃升至92.7%的关键转折点,微软/阿里/Anthropic工程师联合验证的4步调优法
第一章:SITS2026圆桌:智能代码生成未来 2026奇点智能技术大会(https://ml-summit.org) 在SITS2026圆桌论坛上,来自GitHub、Tabnine、DeepMind与国内大模型实验室的七位核心研发者共同探讨了智能代码生成从“补全助手”迈向“协同编程伙伴”…...
易语言学习路径:从入门到精通
好的,这是一份针对易语言的学习路径指南,帮助你系统性地掌握这门中文编程语言:第一阶段:初识与基础 (1-2周)安装与环境搭建:从官方网站下载易语言安装包。完成安装,熟悉易语言集成开发环境(IDE&…...
Go语言的sync.RWMutex源码分析
Go语言中的sync.RWMutex是并发编程中常用的读写锁实现,它允许多个读操作并行执行,而写操作则独占访问。这种机制在高并发场景下能显著提升性能,尤其适用于读多写少的业务场景。本文将从源码层面深入分析RWMutex的实现原理,帮助开发…...
手把手教你写一个Windows垃圾清理批处理脚本(.bat),一键释放C盘空间
从零构建Windows深度清理大师:定制化批处理脚本实战指南 当C盘亮起红色预警,系统开始龟速运行,大多数人的第一反应是安装各种"一键清理"工具。但这类工具往往伴随着隐私风险、冗余功能甚至捆绑软件。其实Windows系统本身就提供了强…...
罗茨风机行业专题研究:全国知名风机大品牌终身有保障的
随着我国工业现代化进程加速及环保政策趋严,罗茨风机作为污水处理、电力、化工等领域的关键设备,市场需求持续增长。据中国通用机械工业协会统计,2024年我国罗茨风机市场规模达82.3亿元,年复合增长率7.5%,行业呈现技术…...
StarUML 4.0 导出高清无痕图片的逆向工程实践
1. StarUML水印问题的由来与影响 第一次用StarUML导出设计图时,那个醒目的"Unregistered"水印简直让我崩溃。作为一款专业的UML建模工具,StarUML在未注册状态下会在导出的所有图片上添加这个标识,严重影响图表在正式文档和演示中的…...
Open Event Frontend 移动端适配与响应式设计:打造完美跨平台体验
Open Event Frontend 移动端适配与响应式设计:打造完美跨平台体验 【免费下载链接】open-event-frontend The frontend for the Open Event API Server https://test.eventyay.com 项目地址: https://gitcode.com/gh_mirrors/op/open-event-frontend Open Ev…...
从ASTM标准到工程实践:雨流计数法的核心算法与选型指南
1. 雨流计数法:从标准到实战的桥梁 第一次接触雨流计数法是在处理风电塔筒的振动数据时,当时面对长达三个月的采样数据完全无从下手。直到发现ASTM E1049-85标准中这个神奇的方法,才明白原来疲劳分析可以如此优雅。简单来说,雨流计…...
cv_unet_image-colorization效果实测:不同分辨率黑白图上色一致性分析
cv_unet_image-colorization效果实测:不同分辨率黑白图上色一致性分析 1. 项目背景与测试目的 黑白照片上色一直是图像处理领域的热门应用,无论是老照片修复还是艺术创作,都希望能将黑白影像转化为生动的彩色画面。今天我们要评测的是基于U…...
