Javascript 单击菜单项后,汉堡包菜单不会向后折叠
我正在用react路由器建造一个水疗中心。我为它做了一份响应菜单。但我想实现的一件事是在单击菜单项后折叠菜单。我不知道如何实现这一点,有人能告诉我吗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
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是的,它起作用了,伙计,谢谢:)我没想到解决办法会这么简单,谢谢伙计:)