ReactのdivでkeyDownイベントを使用したいとします。私は:onKeyDownイベントがリアクションのdivで機能しない
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>
)
}
それはうまく動作しますが、私はリアクションスタイルでもっとやりたいと思います。試しました
onKeyDown={this.onKeyPressed}
コンポーネントに。しかし、それは反応しません。これは私が思い出したように入力要素に作用します。
Codepen:http://codepen.io/lafisrap/pen/OmyBYG
私はそれをどのように行うことができますか?
申し訳ありません。私は確信していた、私はこれを見逃した。しかし、これは問題ではありません。まだ動作していません。 – Michael
更新された回答。いずれかのキーを押す前に、divをクリックするかフォーカスを合わせる必要があります。 – Panther
しました。動いていない。上記のコードを更新しました。これは、DOMコマンドでうまく動作しますが、リアクションスタイルでは機能しません。 – Michael