代码拉取完成,页面将自动刷新
同步操作将从 没雨溪/qf-sub-menu 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
这是一个基于element-ui二次封装的一个侧边菜单栏组件,能快捷的根据数据,生成响应的子菜单,并且解决路径被激活的时候,菜单不激活的问题
npm i qf-sub-menu -S
yarn add qf-sub-menu
首先需要有一组数据,基于权限生成的用户菜单路由配置数据,这些数据应该是这样的
const routes = [
{
path: 'Welcome',
name: 'Welcome',
component: Welcome,
meta: {
name: '管理首页',
icon: 'iconfont icon-shouye'
}
},
{
path: 'StudentManager',
name: 'StudentManager',
redirect:"/StudentManager/studentProduct",
component: StudentManager,
meta: {
name: '学员管理',
icon: 'iconfont icon-xueyuan'
},
children: [
{
path: 'studentProduct',
name: 'studentProduct',
component: studentProduct,
meta: {
name: '学员项目管理',
icon: 'iconfont icon-wode1'
}
},
{
path: 'studentProfile',
name: 'studentProfile',
component: studentProfile,
meta: {
name: '学员资料',
icon: 'iconfont icon-kaoqin2'
}
},
{
path: 'studentDormitory',
name: 'studentDormitory',
component: studentDormitory,
meta: {
name: '学员宿舍',
icon: 'iconfont icon-shuju2'
}
}
]
}
]
const router = new VueRouter({
routes
})
export default router
如上所示,meta
属性中,name
属性最后会生成菜单名字,如果具有children
属性,那么会对应生成子菜单,icon
属性就是存放的菜单的图标类名(前提先安装字体图标)
引入qf-sub-menu组件,因为我们的组件基于element-ui二次封装,所以,我们要先配置element-ui
安装element-ui
yarn add element-ui
import Vue from "vue"
import App from "./App"
// 引入element-ui
import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'
import qfSubMenu from "qf-sub-menu" //引入我们的组件
Vue.use(ElementUI)
//使用Vue.use()将组件注入到所有的子组件
Vue.use(qfSubMenu)
new Vue({
h=>h(App)
}).$mount('#app')
像正常组件一样使用 ,并且需要注入数据源 属性名必须是 sideMenu(就是3-1所描述的数据源) 代码示例如下:
<el-menu :default-active="$route.path"
class="el-menu-vertical-demo"
text-color="#4e5bf8"
ref="sideMenu"
active-text-color="#E47833"
:collapse="isCollapse">
//我们的组件
<qf-sub-menu :sideMenu='sideMenu'></qf-sub-menu>
</el-menu>
务必配合路由使用
直接在el-menu组件上加上属性 :default-active="$route.path"
//:default-active="$route.path"
<el-menu :default-active="$route.path" //加上此属性
class="el-menu-vertical-demo"
text-color="#4e5bf8"
ref="sideMenu"
active-text-color="#E47833"
:collapse="isCollapse">
<!-- <subMenu :sideMenu='sideMenu'></subMenu> -->
<sub-menu :sideMenu='sideMenu'></sub-menu>
</el-menu>
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。