gpt4 book ai didi

Angular 2 键盘事件

转载 作者:太空狗 更新时间:2023-10-29 16:54:22 28 4
gpt4 key购买 nike

尝试使用 TypeScript 和 Angular 2 监控键盘事件 What is Angular2 way of creating global keyboard shortcuts (a.k.a. hotkeys)?很有帮助,但 tslint ( codelyzer) 对象带有消息

In the "@Component" class decorator you are using the "host" property, this is considered bad practice. Use "@HostBindings", "@HostListeners" property decorator instead.

如何使用推荐的装饰器?我不确定 Angular 2: Host binding and Host listening 中的示例如何适用于我的用例,因为我没有绑定(bind)到任何 DOM 元素。

这是我的演示

@Component({
selector: 'my-app',
template: `
<div>
<h2>Keyboard Event demo</h2>
Start typing to see KeyboardEvent values
</div>
<hr />
KeyboardEvent
<ul>
<li>altKey: {{altKey}}</li>
<li>charCode: {{charCode}}</li>
<li>code: {{code}}</li>
<li>ctrlKey: {{ctrlKey}}</li>
<li>keyCode: {{keyCode}}</li>
<li>keyIdentifier: {{keyIdentifier}}</li>
<li>metaKey: {{metaKey}}</li>
<li>shiftKey: {{shiftKey}}</li>
<li>timeStamp: {{timeStamp}}</li>
<li>type: {{type}}</li>
<li>which: {{which}}</li>
</ul>
`,
host: { '(window:keydown)': 'keyboardInput($event)' }
/*
In the "@Component" class decorator you are using the "host" property, this is considered bad practice.
Use "@HostBindings", "@HostListeners" property decorator instead.
*/

})
export class App {

/* a few examples */
keyboardEvent: any;
altKey: boolean;
charCode: number;
code: string;
ctrlKey: boolean;
keyCode: number;
keyIdentifier: string;
metaKey: boolean;
shiftKey: boolean;
timeStamp: number;
type: string;
which: number;

keyboardInput(event: any) {
event.preventDefault();
event.stopPropagation();

this.keyboardEvent = event;
this.altKey = event.altKey;
this.charCode = event.charCode;
this.code = event.code;
this.ctrlKey = event.ctrlKey;
this.keyCode = event.keyCode;
this.keyIdentifier = event.keyIdentifier;
this.metaKey = event.metaKey;
this.shiftKey = event.shiftKey;
this.timeStamp = event.timeStamp;
this.type = event.type;
this.which = event.which;
}

}

https://plnkr.co/edit/Aubybjbkp7p8FPxqM0zx

最佳答案

import {HostListener} from '@angular/core';

@HostListener('window:keydown', ['$event'])
handleKeyDown(event: KeyboardEvent) {
// event.key === 'ArrowUp'
}
  • @HostBindings('attr.foo') foo = 'bar' 用于将组件实例中的值绑定(bind)到宿主元素,如 class、属性、属性或风格。

关于Angular 2 键盘事件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36695922/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com