vue2/vue3路由權(quán)限管理的方法實(shí)例
1. Vue 路由權(quán)限控制一般有2種方法
a、路由元信息(meta)
b、動態(tài)加載菜單和路由(addRoutes)
2 路由元信息(meta)來進(jìn)行路由權(quán)限控制
2.1 在vue2種的實(shí)現(xiàn)
如果一個網(wǎng)站有不同的角色,比如 管理員 和 普通用戶 ,要求不同的角色能訪問的頁面是不一樣的
這個時候我們就可以 把所有的頁面都放在路由表里 ,只要 在訪問的時候判斷一下角色權(quán)限 。如果有權(quán)限就讓訪問,沒有權(quán)限的話就拒絕訪問,跳轉(zhuǎn)到404頁面
vue-router 在構(gòu)建路由時提供了元信息 meta 配置接口,我們可以在元信息中添加路由對應(yīng)的權(quán)限,然后在路由守衛(wèi)中檢查相關(guān)權(quán)限,控制其路由跳轉(zhuǎn)。
可以在每一個路由的 meta 屬性里,將能訪問該路由的角色添加到 roles 里。用戶每次登陸后,將用戶的角色返回。然后在訪問頁面時,把路由的 meta 屬性和用戶的角色進(jìn)行對比,如果用戶的角色在路由的 roles 里,那就是能訪問,如果不在就拒絕訪問。
以下是vue2的實(shí)現(xiàn)方式:
import VueRouter from 'vue-router';
Vue.use(VueRouter)
...
routes: [
{
path: '/login',
name: 'login',
meta: {
roles: ['admin', 'user']
},
component: () => import('../components/Login.vue')
},
{
path: 'home',
name: 'home',
meta: {
roles: ['admin']
},
component: () => import('../views/Home.vue')
},
]
const router = new VueRouter({
routes
})
export default router
在app.vue文件下引入,注冊全局的路由守衛(wèi)
//假設(shè)有兩種角色:admin 和 user
//從后臺獲取的用戶角色
const role = 'user'
//當(dāng)進(jìn)入一個頁面是會觸發(fā)導(dǎo)航守衛(wèi) router.beforeEach 事件
router.beforeEach((to,from,next)=>{
if(to.meta.roles.includes(role)){
next() //放行
}esle{
next({path:"/404"}) //跳到404頁面
}
})
自此基本上路由的權(quán)限控制就完成了
題外話 在路由守衛(wèi)中也能很好的解決匹配不到路由轉(zhuǎn)404頁面的業(yè)務(wù)需求,實(shí)現(xiàn)如下:
import router from ‘./router‘
router.beforeEach((to, from, next) => {
// ...
if (to.matched.length === 0) {
next('/404')
} else {
next()
}
//console.log(to, from, next, '路由守衛(wèi)')
})
2.2 在vue3種的實(shí)現(xiàn)
其實(shí)思路都是差不多的,只是要注意的是vue3中使用路由的方式和vue2有一些細(xì)微的差異,使用我用更簡單的404去創(chuàng)建vue3的實(shí)例,關(guān)于vue3的路由權(quán)限控制可以按vue2和下面代碼依葫蘆畫瓢,實(shí)現(xiàn)代碼如下:
創(chuàng)建路由:
import { createRouter, createWebHashHistory } from 'vue-router';
...
routes: [
{
path: '/login',
name: 'login',
meta: {
roles: ['admin', 'user']
},
component: () => import('../components/Login.vue')
},
{
path: 'home',
name: 'home',
meta: {
roles: ['admin']
},
component: () => import('../views/Home.vue')
},
]
const router = createRouter({
history: createWebHashHistory(),
routes: routers
})
export default router;
路由守衛(wèi)(在App.vue里面進(jìn)行全局注冊):
import {
useRouter
} from 'vue-router';
export default {
name: 'App',
setup() {
const router = useRouter();
router.beforeEach((to, from, next) => {
// ...
if (to.matched.length === 0) {
next('/404')
} else {
next()
}
})
}
}
4 . 動態(tài)加載菜單和路由(addRoutes)
根據(jù)用戶權(quán)限或者是用戶屬性去動態(tài)的添加菜單和路由表,可以實(shí)現(xiàn)對用戶的功能進(jìn)行定制,vue-router 提供了 addRoutes() 方法,可以動態(tài)注冊路由, 需要注意的是,動態(tài)添加路由是在路由表中 push 路由,由于路由是按順序匹配的,因此需要將諸如404頁面這樣的路由放在動態(tài)添加的最后
5.總結(jié)
不管是vue2還是vue3,其實(shí)實(shí)現(xiàn)思想都差不多,只是使用接口細(xì)節(jié)會有少許的不一樣,使用對我們來說學(xué)習(xí)的重點(diǎn)千萬不能放在某一個框架上,而是要訓(xùn)練自己的思維
到此這篇關(guān)于vue2/vue3路由權(quán)限管理的文章就介紹到這了,更多相關(guān)vue路由權(quán)限管理內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue3引入highlight.js進(jìn)行代碼高亮的方法實(shí)例
最近忙著開發(fā)自己的開發(fā)腳手架,在做代碼生成器的時候,有個預(yù)覽功能,需要讓代碼高亮,下面這篇文章主要給大家介紹了關(guān)于vue3引入highlight.js進(jìn)行代碼高亮的相關(guān)資料,需要的朋友可以參考下2022-04-04
element UI 中的 el-tree 實(shí)現(xiàn) checkbox&n
在日常項(xiàng)目開發(fā)中,會經(jīng)常遇到,樹形結(jié)構(gòu)的查詢方式,為了快速方便開發(fā),常常會使用到快捷的ui組件去快速搭樹形結(jié)構(gòu),這里我用的是 element ui 中的 el-tree,對element UI 中的 el-tree 實(shí)現(xiàn) checkbox 單選框及 bus 傳遞參數(shù)的方法感興趣的朋友跟隨小編一起看看吧2022-09-09
vue_drf實(shí)現(xiàn)短信驗(yàn)證碼
我們在做網(wǎng)站開發(fā)時,登錄頁面很多情況下是可以用手機(jī)號接收短信驗(yàn)證碼,本文主要介紹了vue_drf實(shí)現(xiàn)短信驗(yàn)證碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-07-07
解決vue中修改export default中腳本報(bào)一大堆錯的問題
今天小編就為大家分享一篇解決vue中修改export default中腳本報(bào)一大堆錯的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08
Vue-router結(jié)合transition實(shí)現(xiàn)app前進(jìn)后退動畫切換效果的實(shí)例
下面小編就為大家?guī)硪黄猇ue-router結(jié)合transition實(shí)現(xiàn)app前進(jìn)后退動畫切換效果的實(shí)例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-10-10
Vue2實(shí)現(xiàn)圖片的拖拽,縮放和旋轉(zhuǎn)效果的示例代碼
這篇文章主要為大家介紹了如何基于vue2?實(shí)現(xiàn)圖片的拖拽、旋轉(zhuǎn)、鼠標(biāo)滾動放大縮小等功能。文中的示例代碼講解詳細(xì),感興趣的小伙伴可以嘗試一下2022-11-11

