Je souhaite utiliser un événement keyDown sur un div dans React. Je fais:L'événement onKeyDown ne fonctionne pas sur divs dans 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>
)
}
Cela fonctionne très bien, mais je voudrais le faire plus dans le style React. J'ai essayé
onKeyDown={this.onKeyPressed}
sur le composant. Mais ça ne réagit pas. Cela fonctionne sur les éléments d'entrée si je me souviens bien.
Codepen: http://codepen.io/lafisrap/pen/OmyBYG
Comment puis-je faire?
Désolé. J'étais sûr, j'ai juste négligé le ceci. Mais ce n'est pas le problème. Ça ne marche toujours pas. – Michael
mise à jour de la réponse. Vous devriez soit cliquer sur la div ou l'amener à se concentrer avant d'appuyer sur n'importe quelle touche. – Panther
Je l'ai fait. Ça ne fonctionne pas. J'ai mis à jour le code ci-dessus. Cela fonctionne bien avec les commandes DOM, mais pas dans le style React. – Michael