那我們現(xiàn)在就可以開始使用addRoutes進行路由匹配了。下面看代碼:
// router/index.js /** * 根據(jù)權(quán)限匹配路由 * @param {array} permission 權(quán)限列表(菜單列表) * @param {array} asyncRouter 異步路由對象 */ function routerMatch(permission, asyncRouter) { return new Promise((resolve) => { const routers = []; // 創(chuàng)建路由 function createRouter(permission) { // 根據(jù)路徑匹配到的router對象添加到routers中即可 permission.forEach((item) => { if (item.children && item.children.length) { createRouter(item.children) } let path = item.path; // 循環(huán)異步路由,將符合權(quán)限列表的路由加入到routers中 asyncRouter.find((s) => { if (s.path === '') { s.children.find((y) => { if (y.path === path) { y.meta.permission = item.permission; routers.push(s); } }) } if (s.path === path) { s.meta.permission = item.permission; routers.push(s); } }) }) } createRouter(permission) resolve([routers]) }) }
然后我們編寫導(dǎo)航鉤子
// router/index.js router.beforeEach((to, form, next) => { if (sessionStorage.getItem('token')) { if (to.path === '/') { router.replace('/index') } else { console.log(store.state.list.length); if (store.state.list.length === 0) { //如果沒有權(quán)限列表,將重新向后臺請求一次 store.dispatch('getPermission').then(res => { //調(diào)用權(quán)限匹配的方法 routerMatch(res, asyncRouterMap).then(res => { //將匹配出來的權(quán)限列表進行addRoutes router.addRoutes(res[0]); next(to.path) }) }).catch(() => { router.replace('/') }) } else { if (to.matched.length) { next() } else { router.replace('/') } } } } else { if (whiteList.indexOf(to.path) >= 0) { next() } else { router.replace('/') } } });
到這里我們已經(jīng)完成了對頁面訪問的權(quán)限控制,接下來我們來講解一下操作按扭的權(quán)限部分。
四、數(shù)據(jù)操作權(quán)限
是否還記得前面的路由配置中我們多出來的一個代碼,下面我們拿出來看看:
//異步路由(需要權(quán)限的頁面) export const asyncRouterMap = [ { path: '/resource', name: 'nav.Resource', meta: { permission: [] }, component: (resolve) => require(['@/components/Resource/resource'], resolve) }, { path: '/template', name: 'nav.Template', meta: { permission: [] }, component: (resolve) => require(['@/components/Template/template'], resolve) }, { path: '/generalSet', name: 'nav.System', meta: { permission: [] }, component: (resolve) => require(['@/components/SystemSet/generalSet'], resolve) }, { path: '', name: 'nav.Log', component: App, children: [ { path: '/userLog', name: 'nav.UserLog', meta: { permission: [] }, component: (resolve) => require(['@/components/Log/userLog'], resolve), }, { path: '/operatingLog', name: 'nav.SystemLog', meta: { permission: [] }, component: (resolve) => require(['@/components/Log/operatingLog'], resolve), }, ] } ] ];
為每個路由頁面增加meta字段。在routerMatch函數(shù)中將匹配到的詳細(xì)權(quán)限字段賦值到這里。這樣在每個頁面的route對象中就會得到這個字段。
asyncRouter.find((s) => { if (s.path === '') { s.children.find((y) => { if (y.path === path) { //賦值 y.meta.permission = item.permission; routers.push(s); } }) } if (s.path === path) { s.meta.permission = item.permission; routers.push(s); } })
接下來我們編寫一個vue自定義指令對頁面中需要進行鑒權(quán)的元素進行判斷,比如類似這樣的:
<a @click="upload" v-allow="'3'"></a> /* 3代表一個上傳權(quán)限的ID,權(quán)限中有3則顯示按鈕 */
我們直接注冊一個全局指令,利用vnode來訪問vue的方法。代碼如下:
//main.js //按扭權(quán)限指令 Vue.directive('allow', { inserted: (el, binding, vnode) => { let permissionList = vnode.context.$route.meta.permission; if (!permissionList.includes(binding.value)) { el.parentNode.removeChild(el) } } })
至此為止,權(quán)限控制流程就已經(jīng)完全結(jié)束了,在最后我們再看一下完整的權(quán)限控制流程圖吧.
五、路由控制完整流程圖
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com