(94)Wangdao.com_第二十七天_键盘事件
键盘事件
键盘事件由用户击打键盘触发
- 主要有 keydown、keyup 、keypress三个事件,它们都继承了 KeyboardEvent 接口。
- keydown 按下键时 触发
- keyup 松开键时 触发
- keypress 按下有值的键时 触发
即按下 Ctrl、Alt、Shift、Meta 这样无值的键,这个事件不会触发。
对于有值的键,按下时先触发 keydown 事件,再触发这个事件。
- 如果用户按下 不放时,就会连续触发键盘事件
keydown
keypress
keydown
keypress
...(重复以上过程)
终于松开了 keyup- KeyboardEvent 接口
描述用户与键盘的互动。
这个接口继承了 Event 接口,并且定义了自己的实例属性和实例方法
- 浏览器原生提供 KeyboardEvent 构造函数
用来新建键盘事件的实例
var keyEvent = new KeyboardEvent(type, options)
第一个参数是字符串,表示事件类型;
第二个参数是一个事件配置对象,该参数可选。
除了 Event
接口提供的属性,还可以配置以下字段,它们都是可选的
key 字符串 当前按下的键,默认为空字符串。
code 字符串 表示当前按下的键的字符串形式,默认为空字符串。
location 整数 当前按下的键的位置,默认为0。
ctrlKey 布尔值 是否按下 Ctrl 键,默认为false。
shiftKey 布尔值 是否按下 Shift 键,默认为false。
altKey 布尔值 是否按下 Alt 键,默认为false。
metaKey 布尔值 是否按下 Meta 键,默认为false。
repeat 布尔值 是否重复按键,默认为false- KeyboardEvent 的实例属性
event.altKey 是否按下 Alt 键
event.ctrlKey 是否按下 Ctrl 键
event.metaKey 是否按下 meta 键(Mac 系统是一个四瓣的小花,Windows 系统是 windows 键)
event.shiftKey 是否按下 Shift 键
- function showChar(e) {
- console.log('ALT: ' + e.altKey);
- console.log('CTRL: ' + e.ctrlKey);
- console.log('Meta: ' + e.metaKey);
- console.log('Meta: ' + e.shiftKey);
- };
- document.body.addEventListener('keydown', showChar, false);
- function showChar(e) {
event.code 返回一个字符串
表示当前按下的键的字符串形式。
该属性只读。
下面是一些常用键的字符串形式,其他键请查文档
数字键0 - 9 返回 digital0 - digital9
字母键A - z 返回 KeyA - KeyZ
功能键F1 - F12 返回 F1 - F12
方向键 返回 ArrowDown、ArrowUp、ArrowLeft、ArrowRight
Alt 键 返回 AltLeft 或 AltRight
Shift 键 返回 ShiftLeft 或 ShiftRight
Ctrl 键 返回 ControLeft 或 ControlRight
event.key 返回一个字符串
表示按下的键名。
该属性只读。
如果按下的键代表可打印字符,则返回这个字符,比如数字、字母
如果按下的键代表不可打印的特殊字符,则返回预定义的键值,
比如 Backspace,Tab,Enter,Shift,Control,Alt,CapsLock,
Esc,Spacebar,PageUp,PageDown,End,Home,Left,
Right,Up,Down,PrintScreen,Insert,Del,Win,F1~F12,
NumLock,Scroll 等
如果同时按下一个 控制键 和一个 符号键 ,则返回符号键的键名。比如,按下 Ctrl + a,则返回a;按下 Shift + a,则返回大写的 A
如果无法识别键名,返回字符串 "Unidentified"
event.location 返回一个整数,
表示按下的键处在键盘的哪一个区域。
0 键盘的主区域,或者无法判断处于哪一个区域。
1 键盘的左侧,只适用那些有两个位置的键(比如 Ctrl 和 Shift 键)。
2 键盘的右侧,只适用那些有两个位置的键(比如 Ctrl 和 Shift 键)。
3 数字小键盘。
event.repeat 返回一个布尔值
代表该键是否被按着不放,以便判断是否重复这个键
即浏览器会持续触发 keydown 和 keypress 事件,直到用户松开手为止
- event.getModifierState() 返回一个布尔值
表示是否按下或激活指定的功能键
- Alt Alt 键
CapsLock 大写锁定键
Control Ctrl 键
Meta Meta 键
NumLock 数字键盘开关键
Shift Shift 键 - if ( event.getModifierState('Control') +
- event.getModifierState('Alt') +
- event.getModifierState('Meta') > 1){ //只要Control、Alt、Meta里面,同时按下任意两个或两个以上的键就返回
- return;
- }
- if ( event.getModifierState('Control') +
(94)Wangdao.com_第二十七天_键盘事件的更多相关文章
- (93)Wangdao.com_第二十六天_鼠标事件
鼠标事件 与鼠标相关的事件,继承了 MouseEvent 接口 分类: click 按下鼠标(通常是按下主按钮)时触发. mousedown 首先触发,mouseup 接着 ...
- (96)Wangdao.com_第二十九天_表单事件
表单事件 input 事件 select 事件 change 事件 invalid 事件 reset 事件 submit 事件 ...
- JavaScript的事件对象_键盘事件
用户在使用键盘时会触发键盘事件.“DOM2 级事件”最初规定了键盘事件,结果又删除了相应的内容.最终还是使用最初的键盘事件,不过 IE9 已经率先支持“DOM3”级键盘事件. 一.键码 在发生 key ...
- (95)Wangdao.com_第二十八天_进度事件
进度事件 进度事件 用来描述资源加载的进度, 主要由 AJAX 请求.<img>.<audio>.<video>.<style>.<link> ...
- (92)Wangdao.com_第二十五天_线程机制_H5 Web Workers 分线程任务_事件 Event
浏览器内核 支撑浏览器运行的最核心的程序 IE 浏览器内核 Trident内核,也是俗称的IE内核Chrome 浏览器内核 统称为 Chromium 内核或 ...
- 第二十七课:滚轮事件,mouseenter与mouseleave事件的修复
滚轮事件 jQuery核心库没有对mousewheel事件的差异性进行处理,但作为一个常用的事件,本文讲解一下. mousewheel事件只有火狐浏览器不支持.mousewheel用于取得滚动距离的属 ...
- javaSE第二十七天
第二十七天 447 1:反射(理解) 447 (1)类的加载及类加载器 447 (2)反射: 448 A:定义 448 B:获取字节码对象的三种方式 449 (3) ...
- 深入理解DOM事件类型系列第二篇——键盘事件
× 目录 [1]类型 [2]顺序 [3]按键信息[4]应用 前面的话 鼠标和键盘是电脑端主要的输入设备,上篇介绍了鼠标事件,本文将详细介绍键盘事件 类型 键盘事件用来描述键盘行为,主要有keydown ...
- NeHe OpenGL教程 第二十七课:影子
转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...
随机推荐
- 使用InternalsVisibleTo给assembly添加“友元assembly”
C#的internal关键字可以使标记的方法,字段或者属性等等只能在当前assembly内部使用,那么如果其他的assembly需要使用这个internal的方法的时候怎么办呢?.NET提供了一种类似 ...
- springBoot总结
springBoot总结: ssm基本的依赖: <dependencies> <!--添加依赖thymeleaf 可以访问html页面--> <!--<depend ...
- 第六节:深入研究Task实例方法ContinueWith的参数TaskContinuationOptions
一. 整体说明 揭秘: 该章节的性质和上一个章节类似,也是一个扩展的章节,主要来研究Task类下的实例方法ContinueWith中的参数TaskContinuationOptions. 通过F12查 ...
- 闭包创建自己的 plugin 示例 加载 loading
plugin 插件 什么是 plugin? 实现一个功能,与主应用程序分离,减少主应用程序的大小,高复用,可维护 制作过程中,一定要避免依赖其他的元素,减少 id 等的使用,避免与页面中其他内容冲突 ...
- Design Principles and Design Patterns
设计原则解读. 设计原则是对设计模式的约束性要求,属于设计中基本的四项特征,不符合此四项特征的设计,不具有生命力. 设计模式也是在此四项设计原则上的具体化实例化衍生物. Martin原文: http: ...
- SQLServer数据库文件由高版本向低版本转换
这个只能用2012的生成脚本功能,在高级里面把脚本兼容设置成2008,并且选择生成架构和数据(默认是只有架构)拿这个脚本在2008上跑一次就行了 sqlserver 中使用sqlcmd 执行*.sql ...
- token的设置与获取
以用户登录为例: application-resources.yml: #用户session在redis中保存的key REDIS_STU_SESSION_KEY: REDIS_USER_SESSIO ...
- localhost和127.0.0.1的区别
localhost(local)是不经网卡传输,它不受网络防火墙和网卡相关的的限制. 127.0.0.1是通过网卡传输,依赖网卡,并受到网络防火墙和网卡相关的限制. ::1 是IPv6中的12 ...
- jQuery ajaxForm和 ajaxSubmit注意
http://jquery.malsup.com/form/#file-upload 在使用jQuery异步上传时,需要注意在存在文件上传时,要将返回数据的contentType设置为text/htm ...
- 【easy】100. Same Tree
判断两棵二叉树是否相等 /** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left ...