JS-事件对象(鼠标键盘事件)
一 事件对象
1 需要获取键盘和鼠标的信息的时候,用到事件对象。(e)
例如:document.onclick = function(e){
var e = e || event;(做兼容)
}
注意:由于事件对象有兼容性,在IE中传不传参数无所谓,但是输出的参数必须是event。
2 查看用户点击了鼠标的那个键:e.button
e.button == 0:代表左键 1:代表滚轮 2:代表右键
3 事件对象 坐标
clientX clientY 可视区的x和y坐标;(可视区可以肤浅理解为一屏的body)
offsetX offsetY 当前元素自身身上的坐标;(相对于第一个定位父级)
pageX pageY 页面的坐标(包括滚动条);
screenX screenY 屏幕的坐标;(整个电脑的屏幕);
4 键盘中onkeydown和onkeyPress区别
前者按键盘上的任意字符都可以,后者只能识别字母和数字以及一些常用字符;
后者不支持ALT和SHIFT键;
前者回车键的ASCII码的值是13,后者是10。
5 如何知道用户按下了哪个键
e.keyCode (兼容) e.which (返回值是ASCII码);
需要的话可以用String.fromCharCode 将ASCII码转化为字符进行操作;
二 事件监听
addEventListener()三个参数;
第一个参数是事件名称,不需要加 on ,但是事件要用引号括起来;
第二个参数是回调函数;
第三个参数是布尔值,一般情况是false,true代表是捕获。
三 事件冒泡
1 IE提出来的事件冒泡。什么是事件冒泡?
从子元素的事件到父元素的事件依次执行的一个过程就是事件冒泡。
2 如何阻止事件冒泡:
e.stopPropagation()兼容e.cancelBubble = true;
四 事件捕获
1 网景公司提出来的。什么是事件捕获?
从父元素的事件到子元素的事件依次执行的一个过程就是事件捕获。
2 注意:IE是事件冒泡,火狐是事件捕获。
3 当事件冒泡遇到事件捕获的时候会先捕获再冒泡。
五 事件代理(事件委托)
1 利用事件冒泡的机制将子元素的事件加到父级身上。
2 事件代理优点:
减少了dom的绑定,提高了性能;
可以给未来的元素添加事件。
3 查看用户点击了那个对象?
e.srcElement 兼容 e.target (返回的是大写字符);
JS-事件对象(鼠标键盘事件)的更多相关文章
- React 事件对象、键盘事件、表单事件、ref获取dom节点、react实现类似Vue双向数据绑定
1.案例实现代码 import React, { Component } from 'react'; /** * 事件对象.键盘事件.表单事件.ref获取dom节点.react实现类似Vue双向数据绑 ...
- 常用MouseEvent鼠标事件对象&KeyboardEvent键盘事件对象&常用键盘码
MouseEvent鼠标事件对象: e.target //=> 事件源(操作的是哪个元素) e.clientX e.clientY //当前鼠标触发点距离当前窗口左上角的X|Y轴坐标 e.pag ...
- JavaScript的事件对象_键盘事件
用户在使用键盘时会触发键盘事件.“DOM2 级事件”最初规定了键盘事件,结果又删除了相应的内容.最终还是使用最初的键盘事件,不过 IE9 已经率先支持“DOM3”级键盘事件. 一.键码 在发生 key ...
- js进阶 12-4 jquery键盘事件如何使用
js进阶 12-4 jquery键盘事件如何使用 一.总结 一句话总结:键盘和鼠标都是外设输入设备,所以函数很像,所以使用就像鼠标事件click一样 1.jquery键盘事件有哪三个? 1(up和do ...
- Tkinter 鼠标键盘事件(一)
一: 鼠标事件 <Button-1> 鼠标左键单击 ...
- Linux 模拟 鼠标 键盘 事件
/************************************************************************ * Linux 模拟 鼠标 键盘 事件 * 说明: ...
- Python——pyHook监听鼠标键盘事件
pyHook包为Windows中的全局鼠标和键盘事件提供回调. 底层C库报告的信息包括事件的时间,事件发生的窗口名称,事件的值,任何键盘修饰符等. 而正常工作需要pythoncom等操作系统的API的 ...
- Python - selenium_WebDriver 鼠标键盘事件
from selenium import webdriver #引入ActionChains类 提供了鼠标的操作方法 from selenium.webdriver.common.action_cha ...
- Selenium4.0+Python3系列(四) - 常见元素操作(含鼠标键盘事件)
一.写在前面 上篇文章介绍的是关于浏览器的常见操作,接下来,我们将继续分享关于元素的常见操作,建议收藏.转发! 二.元素的状态 在操作元素之前,我们需要了解元素的常见状态. 1.常见元素状态判断,傻傻 ...
- 简单总结焦点事件、Event事件对象、冒泡事件
每学习一些新的东西,要学会复习,总结和记录. 今天来简单总结一下学到的几个事件:焦点事件.Event事件对象.冒泡事件 其实这几个事件应该往深的说是挺难的,但今天主要是以一个小菜的角度去尝试理解一些基 ...
随机推荐
- sourcetree回退已推送的代码
方法一: https://blog.csdn.net/gang544043963/article/details/71511958 我百度到博主用这种界面的方式进行的,可视化很好.我想应该可以很好的回 ...
- mac maven lombok报错
maven已导入lombok的jar包,注解@Data,但是用到getter,setter时依然出错.解决办法: 打开eclipse.ini文件,加上如下两句: -Xbootclaspath//Use ...
- Postman用法,了解一下
一.Postman的基础功能 二.接口请求流程 1. GET 请求 GET请求:点击Params,输入参数及value,可输入多个,即时显示在URL链接上, 所以,GET请求的请求头与请求参数如在接口 ...
- 【MySql】【Navicat】下载,安装,激活攻略
来了一家新公司,新电脑,最近申请了DB访问的权限. 公司用的MySql数据库,自己下载了MySql workbench,用的也还不错. 现在下载了一个Navicat,比较讨厌的是,现在很多软件都需要注 ...
- [UnityShader基础]02.深度测试 & 深度写入
参考链接: https://blog.csdn.net/v_xchen_v/article/details/79380222 前面说到了渲染队列,对于两个不透明的物体A和B,它们处于同一个渲染队列中. ...
- 网站分析基础及KPI实践
一:网站分析是什么? 网站分析(Web Analytics)即网站访客行为分析,通过对网站数据进行定量和定性的分析,来不断驱动和提高访问者在网站中的体验,并将访客转化为你的商业目标(在线及离线KPI) ...
- SAP HANA HDBSQL命令
1.登录: window操作系统下面: 打开C:\Program Files\SAP\hdbclient\hdbsql.exe \c 连接数据库 connect的缩写 HANA hostname: ...
- Linux——JDK配置
一.安装jdk-7u21-linux-x64.rpm文件 [root@centos6 local]# rpm –ivh jdk-7u21-linux-x64.rpm 二.防火墙开放8080端口 (在 ...
- 字符串流stringReader
String info ="good good study day day up";StringReader stringReader = new StringReader(inf ...
- WeakReference与SoftReference
WeakReference与SoftReference都可以用来保存对象的实例引用,这两个类与垃圾回收有关. WeakReference是弱引用,其中保存的对象实例可以被GC回收掉.这个类通常用于在某 ...