React JSを使用してメニューバーを構築しています。メニュー項目をクリックすると、それぞれのメガメニューが開きます。メガメニューの外側をクリックすると、それは閉じなければなりません。私はmegamenuの状態を切り替えることによってこれを作った。メニュー項目をもう一度クリックすると(メニュー項目をクリックしてメガメニューを閉じたり開いたりする)メガメニューを閉じることもできます。私はここでスタックしています。メニュー項目を2回クリックすると、状態は元に戻りません。React onClick状態が戻っていない
class Menubar extends React.Component {
constructor() {
super();
this.state = {
clicked: false
};
this.handleClick = this.handleClick.bind(this);
this.handleOutsideClick = this.handleOutsideClick.bind(this);
}
componentWillMount() {
document.addEventListener('click', this.handleOutsideClick, false);
}
componentWillUnmount(){
document.removeEventListener('click', this.handleOutsideClick, false);
}
handleClick() {
this.setState({clicked: !this.state.clicked});
}
handleOutsideClick(){
if (this.refs.megaMenu.contains(event.target)) {
} else {
this.setState({
clicked: false
});
}
}
render() {
return (
<div className="container">
<div className="menu-bar">
{/* Menu*/}
<div className="menu-bar-item">
<a className="menu-bar-link" href="#" onClick={this.handleClick}>Points</a>
<div className={"mega-menu"+" "+this.state.clicked} ref="megaMenu">
<div className="mega-menu-content">
<p>Points Menu</p>
</div>
</div>
</div>
</div>
</div>
);
}
}
ReactDOM.render(
<Menubar />,
document.getElementById('example')
);
あなたの答えで私の間違いを説明していただきありがとうございます:) –