Javascript 单击菜单项后,汉堡包菜单不会向后折叠

Javascript 单击菜单项后,汉堡包菜单不会向后折叠,javascript,html,css,reactjs,responsive-design,Javascript,Html,Css,Reactjs,Responsive Design,我正在用react路由器建造一个水疗中心。我为它做了一份响应菜单。但我想实现的一件事是在单击菜单项后折叠菜单。我不知道如何实现这一点,有人能告诉我吗 var { Router, Route, IndexRoute, IndexLink, Link } = ReactRouter; class App extends React.Component { constructor() { super(); this.state = { me

我正在用react路由器建造一个水疗中心。我为它做了一份响应菜单。但我想实现的一件事是在单击菜单项后折叠菜单。我不知道如何实现这一点,有人能告诉我吗

var { Router, Route, IndexRoute, IndexLink, Link } = ReactRouter;

class App extends React.Component {
    constructor() {
        super();
        this.state = {
          menuVisible: false
        };
        this.handleClick = this.handleClick.bind(this);
    }

    handleClick() {
        this.setState({menuVisible: !this.state.menuVisible});
    }
    render() {
        return (
            <div className="wrapper">
                <div className="header">
                    <div className="topbar">
                        <a className={"menu"+" "+this.state.menuVisible} onClick={this.handleClick}><i className="zmdi zmdi-menu"></i></a>
                        <a className="logo">Dummy SPA</a>
                    </div>
                    <div className={"menubar"+" "+this.state.menuVisible}>
                        <ul>
                            <li><IndexLink to="/" activeClassName="active">Home</IndexLink></li>
                            <li><Link to="deals" activeClassName="active">Deals</Link></li>
                            <li><Link to="orders" activeClassName="active">Orders</Link></li>
                            <li><Link to="support" activeClassName="active">Support</Link></li>
                        </ul>
                    </div>
                </div>

                <div className="container">
                    {this.props.children}
                </div>
            </div>
        );
    }
}

//Dummy Pages
class Home extends React.Component {
    render() {
        return (
            <div className="page">
                <h1>Home</h1>
            </div>
        );
    }
}

class Deals extends React.Component {
    render() {
        return (
            <div className="page">
                <h1>Deals</h1>
            </div>
        );
    }
}

class Orders extends React.Component {
    render() {
        return (
            <div className="page">
                <h1>Orders</h1>
            </div>
        );
    }
}

class Support extends React.Component {
    render() {
        return (
            <div className="page">
                <h1>Support</h1>
            </div>
        );
    }
}

//Router Rendering
ReactDOM.render(
    <Router>
        <Route path="/" component={App}>
            <IndexRoute component={Home} />
            <Route path="deals" component={Deals}/>
            <Route path="orders" component={Orders}/>
            <Route path="support" component={Support} />
        </Route>
    </Router>,
    document.getElementById('app')
);
var{Router,Route,IndexRoute,IndexLink,Link}=ReactRouter;
类应用程序扩展了React.Component{
构造函数(){
超级();
此.state={
menuVisible:错误
};
this.handleClick=this.handleClick.bind(this);
}
handleClick(){
this.setState({menuVisible:!this.state.menuVisible});
}
render(){
返回(

.

您已经有了一个菜单图标的单击处理程序,可以在单击时显示/隐藏菜单。我只需将相同的处理程序添加到每个菜单项:

render() {
    return (
        <div className="wrapper">
            <div className="header">
                <div className="topbar">
                    <a className={"menu"+" "+this.state.menuVisible} onClick={this.handleClick}><i className="zmdi zmdi-menu"></i></a>
                    <a className="logo">Dummy SPA</a>
                </div>
                <div className={"menubar"+" "+this.state.menuVisible}>
                    <ul>
                        <li><IndexLink to="/" activeClassName="active" onClick={this.handleClick}>Home</IndexLink></li>
                        <li><Link to="deals" activeClassName="active" onClick={this.handleClick}>Deals</Link></li>
                        <li><Link to="orders" activeClassName="active" onClick={this.handleClick}>Orders</Link></li>
                        <li><Link to="support" activeClassName="active" onClick={this.handleClick}>Support</Link></li>
                    </ul>
                </div>
            </div>

            <div className="container">
                {this.props.children}
            </div>
        </div>
    );
render(){
返回(
虚拟温泉
  • 交易
  • 命令
  • 支持
{this.props.children} );
Home为每个IndexLink添加HandleClick事件,或者在
    tag@tsb是的,它起作用了,伙计,谢谢:)我没想到解决办法会这么简单,谢谢伙计:)