KeyboardEvent.initKeyEvent()
警告:
不要再使用这个方法,而是使用 KeyboardEvent()
构造函数。
该方法已从 DOM 规范中删除,并且不受任何现代浏览器支持。Firefox 从版本 93 开始默认通过首选项(dom.keyboardevent.init_key_event.enabled
)隐藏此方法,并计划很快移除它。
已弃用: 不再推荐使用该特性。虽然一些浏览器仍然支持它,但也许已从相关的 web 标准中移除,也许正准备移除或出于兼容性而保留。请尽量不要使用该特性,并更新现有的代码;参见本页面底部的兼容性表格以指导你作出决定。请注意,该特性随时可能无法正常工作。
KeyboardEvent.initKeyEvent 方法用于初始化使用document.createEvent
("KeyboardEvent") 创建的事件的值。以这种方式初始化的事件必须使用document.createEvent
("KeyboardEvent") 方法创建。在调度之前,必须调用 initKeyEvent 来设置事件。
语法
initKeyEvent (type, bubbles, cancelable, view,
ctrlKey, altKey, shiftKey, metaKey,
keyCode, charCode)
参数
-
type
- : 是表示事件类型的
DOMString
。
- : 是表示事件类型的
-
bubbles
- : 是
Boolean
指示事件是否应该通过事件链冒泡(请参阅冒泡)。
- : 是
-
cancelable
- : 是
Boolean
我指出事件是否可以被取消(见可取消)。
- : 是
-
viewArg
- : 指定
UIEvent.view
; 此值可能为空。
- : 指定
-
ctrlKey
-
: 如果要生成的虚拟键是包含
Ctrl
键的键的组合,则为
Boolean
-
-
altKey
-
_: 如果要生成的虚拟键是包含
Alt
键的键的组合,则为
Boolean
。
-
-
shiftKey
-
: A
Boolean
如果要生成的虚拟键是包含Shift
键的键组合,则返回 true。
-
-
metaKey
-
_: 是
Boolean
如果要生成的虚拟键是包含Meta
键的键的组合,则为
true
。
-
-
keyCode
- : 是一个无符号长整型,表示被按下的键的虚拟键码值,否则为 0.请参阅
KeyboardEvent.keyCode
以获取键码列表。
- : 是一个无符号长整型,表示被按下的键的虚拟键码值,否则为 0.请参阅
-
charCode
- : 是一个无符号长整型,表示与按下的键相关的 Unicode 字符,否则为 0。
示例
const event = document.createEvent("KeyboardEvent"); // 创建 key 事件
// 定义事件
event.initKeyEvent(
"keypress", // type 参数
true, // canBubble 参数
true, // cancelable 参数
null, // view 参数,指定 UIEvent.view。该值应为 null。
false, // ctrlKey 参数
false, // altKey 参数
false, // shiftKey 参数
false, // metaKey 参数
9, // keyCode 参数
0, // charCode 参数
);
document.getElementById("blah").dispatchEvent(event);
规范
键盘事件的这种实现基于 DOM 2 事件早期版本中的关键事件规范,后来从该规范中删除。
initKeyEvent 是 DOM Level 3 事件的当前 Gecko 等价物(最初起草并且不推荐使用KeyboardEvent()
Keyboard.initKeyboardEvent()
方法与以下参数: