Ответ 1
Вы должны использовать атрибут tabIndex, чтобы иметь возможность прослушивать событиеKeyDown на div в React. Установка tabIndex = "0" должна запускать ваш обработчик.
Я хочу использовать событие keyDown для div в React. Я делаю:
componentWillMount() {
document.addEventListener("keydown", this.onKeyPressed.bind(this));
}
componentWillUnmount() {
document.removeEventListener("keydown", this.onKeyPressed.bind(this));
}
onKeyPressed(e) {
console.log(e.keyCode);
}
render() {
let player = this.props.boards.dungeons[this.props.boards.currentBoard].player;
return (
<div
className="player"
style={{ position: "absolute" }}
onKeyDown={this.onKeyPressed} // not working
>
<div className="light-circle">
<div className="image-wrapper">
<img src={IMG_URL+player.img} />
</div>
</div>
</div>
)
}
Это отлично работает, но я бы хотел сделать это больше в стиле React. Я пытался
onKeyDown={this.onKeyPressed}
на компоненте. Но это не реагирует. Насколько я помню, он работает с элементами ввода.
Как я могу это сделать?
Вы должны использовать атрибут tabIndex, чтобы иметь возможность прослушивать событиеKeyDown на div в React. Установка tabIndex = "0" должна запускать ваш обработчик.
Вам нужно написать это так
<div
className="player"
style={{ position: "absolute" }}
onKeyDown={this.onKeyPressed}
tabIndex="0"
>
Если onKeyPressed
не привязано к this
, попробуйте переписать его с помощью функции стрелки или связать его в компоненте constructor
.
Вы слишком много думаете о чистом Javascript. Избавьтесь от своих слушателей по этим жизненным циклам React и используйте event.key
вместо event.keyCode
(потому что это не объект события JS, это React SyntheticEvent). Весь ваш компонент может быть таким же простым (предполагая, что вы не связали свои методы в конструкторе).
onKeyPressed(e) {
console.log(e.key);
}
render() {
let player = this.props.boards.dungeons[this.props.boards.currentBoard].player;
return (
<div
className="player"
style={{ position: "absolute" }}
onKeyDown={(e) => this.onKeyPressed(e)}
>
<div className="light-circle">
<div className="image-wrapper">
<img src={IMG_URL+player.img} />
</div>
</div>
</div>
)
}