侧边栏菜单组件

component 下新建menu文件,menu下建index.jsx和subitem.jsx

index.jsx

import React, { Component } from 'react';
import {NavLink} from 'react-router-dom'
import SubItem from './subitem' export default class Menu extends React.Component {
constructor(props,context){
super(props,context)
this.state = {
menus:[
{name:'首页',icon:'icon-shouye',show:true,link:'/'},
{name:'公告管理',icon:'icon-gonggao',show:true,link:'/noticelist'},
{name:'人事管理',icon:'icon-yonghu2',show:true,link:'',
submenu:[
{name:'员工档案',link:'/hrmanage/employeefiles',show:true},
{name:'请假申请',link:'/hrmanage/leave',show:true},
]},
{name:'组织架构',icon:'icon-zuzhi1',show:true,link:'/organization'},
{name:'系统管理',icon:'icon-xitong2',show:true,link:'',
submenu:[
{name:'权限设置',link:'/systemset/authorize',show:true},
]
},
]
}
} render() {
let self = this;
return (
<div className="Menu">
<ul>
{
self.state.menus.map(function(item,index){
return <li key={index}
onClick={self.linktosonpage.bind(self,item,index)}>
        {/*如果有二级菜单就显示右边的icon*/}
<i className={`iconfont ${item.icon}`}></i>{item.name}<i className={`youjiantou ${item.submenu?'iconfont icon-youjiantou':''} ${item.show?'rotate':''}`}></i>
{item.submenu
?<SubItem isshow={item.show} items={item.submenu} />:''
}
</li>
})
}
</ul>
</div>
)
} linktosonpage(item,index){
if(item.link){ // item.link是子菜单的路由地址
location.replace(`#${item.link}`);
// this.props.history.push(item.link) // 用这个报错Cannot read property 'push' of undefined
}else{
let that = this;
let data = that.state.menus;
data[index].show = !data[index].show
that.setState({
menus:data
})
}
} }

subitem.jsx

import React, { Component } from 'react';
import { Link } from 'react-router-dom' export default class SubItem extends React.Component { render(){
let self = this;
return(
<div className="SubItem" className={this.props.isshow?'':'hide'}>
{
this.props.items.map(function(i,subindex){
return <div className="item" key={subindex} onClick={self.stoppropgation.bind(self)}>
<Link to={i.link}>{i.name}</Link>
</div>
})
}
</div>
)
} stoppropgation(e){
e.stopPropagation();
}
}

react 侧栏二级菜单组件的更多相关文章

  1. dedecms织梦导航栏二级菜单的实现方法

    dede导航下拉菜单,一级栏目增加二级下拉菜单   使用dedecms5.6——5.7 将这段代码贴到templets\default\head.htm文件里<!-- //二级子类下拉菜单,考虑 ...

  2. element ui aside — 侧栏导航菜单移入移出折叠效果

    效果如图,移入移出控制折叠,点击按钮后移入移出不可控制折叠. 功能是很简单的功能,不过昨天这块还是弄了小一个小时,所以记录下来. 发现的问题: 模版上el-aside写上@mouseenter无效 解 ...

  3. 多种css3时尚侧栏菜单展开显示效果Off-Canvas Menu Effects

    今天我们想分享多种css3时尚侧栏菜单展开显示效果.侧边栏应用广泛,我们之前已经产生了一些效果灵感.风格演变,今天我们要展示一套新的灵感的现代效果.不同的布局和菜单的同步转换和页面可以让一切看起来更有 ...

  4. ionic 侧栏菜单用法

    第一步: 引入js和css文件我这里是直接引入的cdn,ionic是基于angular的,bundle.min.js把常用angular的js已经压缩到一起,可以直接引入.bundle.min.js, ...

  5. Ionic Js十七:侧栏菜单

    一个容器元素包含侧边菜单和主要内容.通过把主要内容区域从一边拖动到另一边,来让左侧或右侧的侧栏菜单进行切换. 效果图如下所示:   用法 要使用侧栏菜单,添加一个父元素,一个中间内容 ,和一个或更 ...

  6. HTML+CSS实现导航栏二级下拉菜单完整代码

    工具是vs code 代码如下 <!DOCTYPE html> <html lang="en"> <head> <meta charset ...

  7. ionic js 侧栏菜单 把主要内容区域从一边拖动到另一边,来让左侧或右侧的侧栏菜单进行切换

    ionic 侧栏菜单 一个容器元素包含侧边菜单和主要内容.通过把主要内容区域从一边拖动到另一边,来让左侧或右侧的侧栏菜单进行切换. 效果图如下所示: 用法 要使用侧栏菜单,添加一个父元素<ion ...

  8. django自定义rbac权限组件(二级菜单)

    一.目录结构 二.表结构设计 model.py from django.db import models # Create your models here. class Menu(models.Mo ...

  9. 手摸手,带你用vue实现后台管理权限系统及顶栏三级菜单显示

    手摸手,带你用vue实现后台管理权限系统及顶栏三级菜单显示 效果演示地址 项目demo展示 重要功能总结 权限功能的实现 权限路由思路: 根据用户登录的roles信息与路由中配置的roles信息进行比 ...

随机推荐

  1. 关于Cocos2d-x中增加暂停按钮的步骤

    1.在GameScene.cpp的init方法中先定义一个里面放着可变换并在变换的时候会响应事件的MenuItem的Menu,这个Menu里面的可变换MenuItem又由两个小MenuItem组成,每 ...

  2. HttpClient学习之 客户端HTTP编程入门

    说明 本文存在的原因,是想深入的学习下HttpClient.对应的网址是: http://hc.apache.org/httpcomponents-client-4.5.x/primer.html h ...

  3. 防止 apk反编译 jocky-- java混淆代码 (转至:http://my.oschina.net/f839903061/blog/72554)

    1.下载jocky,解压后把整个文件夹复制到Eclipse的plugin目录.2.重启Eclipse,在项目上点右键,如果出现jocky菜单,则安装成功. 3.在项目上点右键,选菜单jocky-> ...

  4. chrome 版本升级到56,报错Your connection is not private NET::ERR_CERT_WEAK_SIGNATURE_ALGORITHM

    ubuntu14.04 解决方法: $ sudo apt-get install libnss3-1d ref: http://stackoverflow.com/questions/42085055 ...

  5. yii2的Console定时任务创建

    Yii2的定时任务可以有两种写法,原理都是通过服务器的定时任务去调用 1.通过调用指定的URL访问 就相当于在浏览器中访问 2.通过console调用 下面我们就来说说Console 是如何实现定时任 ...

  6. 关于MySQL的几个命令之load

    1.记录当前操作命令

  7. Unity3D手机平台分辨率自动匹配教程

    1. 下载NGUI 2. 导入NGUI package到Unity. 这时候菜单上会出现NGUI的菜单栏: 3. 将默认的Main Camera删掉,通过菜单栏NGUI->Create新建一个2 ...

  8. liunx下误删除/var目录下的empty文件,导致ssh连接不上

    清理Liunx上不用的文件,导致误删 /var/下的empty文件,因为用的是ftp删的,所以可能有隐藏文件没有看到,导致其他同事都登录不上去 解决方法: 1.在/var文件夹下,重新建立empty文 ...

  9. linux环境判断字符串是否为非空

    需求描述: 今天帮同事调整脚本,涉及到判断一个字符串为非空的,在此记录下. 操作过程: 通过-n来判断字符串是否为非空,如果为非空那么就是真 #!/bin/bash Str1='MyTest' if ...

  10. Android开发之程序猿必需要懂得Android的重要设计理念2(5.20更新版)

    上篇文章介绍了Android开发的设计理念的一部分,并没有得到博友们的多大认可,仅仅看到了一位博友在以下留言期待下一篇文章的发表,为了这小小的唯一支持.我决定继续把后面的8个要点介绍一下,自己也潜心反 ...