ReactのdivでonKeyDownイベントが動作しない
ReactでdivのkeyDownイベントを使いたい。私はそうしています:
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}
を試してみました。しかし反応しません。確かinput要素では動いた。
[コードペン][1]
どうすればいいのでしょうか?
70
3
ReactでdivのonKeyDownイベントをリッスンするには、tabIndex属性を使用する必要があります。tabIndex="0"を設定すると、ハンドラが起動します。
このように書く必要がある。
onKeyPressed
が
thisにバインドされていない場合は、arrow関数を使って書き換えるか、コンポーネントの
constructor`でバインドする。あなたは純粋なJavascriptで考えすぎている。Reactのライフサイクルメソッドのリスナーを取り除いて、
event.keyCode
の代わりにevent.key
を使いましょう(これはJSのイベントオブジェクトではなく、ReactのSyntheticEventだからです)。コンポーネント全体はこのようにシンプルになります(コンストラクタでメソッドをバインドしていないと仮定して)。