中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何上手vue vuex vue-rouert后臺的權限路由

發布時間:2021-09-15 10:44:53 來源:億速云 閱讀:174 作者:柒染 欄目:web開發

這篇文章給大家介紹如何上手vue vuex vue-rouert后臺的權限路由,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

項目地址: vue-simple-template

共三個角色:adan barbara carrie 密碼全是:123456

adan 擁有 最高權限A 他可以看到 red , yellow 和 blue 頁面(共三個頁面)

barbara 擁有 權限B 他可以看到 red 和 yellow 頁面

carrie 擁有 權限C 他可以看到 red 和 blue 頁面

如何上手vue vuex vue-rouert后臺的權限路由

技術棧

webpack ---- 打包神器
vue ---- JavaScript 框架
vuex ---- 實現不同組件間的狀態共享
vue-router ---- 頁面路由
babel-polyfill ---- 將ES6代碼轉為ES5代碼
normalize.css ---- 重置掉該重置的樣式
element-ui ---- UI組件庫

項目初始化

# cd 到項目文件夾
cd weven-simple-template
# 安裝依賴 (本項目還安裝了其他依賴詳情 請見 package.json 文件)
npm install
# 運行項目
npm run dev

項目結構

vue-cil 腳手架初始化項目后,我只修改過src文件夾

src
├── App.vue  ---- 頁面入口
├── api  ---- api請求
│ └── login.js ---- 模擬json對象數據
├── assets  ---- 主題 字體等靜態資源
│ └── logo.png
├── components ---- 組件
│ ├── index.vue
│ └── login.vue 
├── main.js  ---- 初始化組件 加載路由
├── router  ---- 路由
│ └── index.js
└── store  ---- vuex狀態管理
 ├── getters.js
 ├── index.js
 └── modules
 └── login.js

重點:

動態路由的關鍵在于router配置的 meta字段 和vuex的 狀態共存 (不懂可以先查看官方文檔)

router/index.js

// 初始化路由
export default new Router({ 
 routes: [
 {
 path: '/login',
 name: 'Login',
 component: Login
 }
 ] 
});
// 動態路由 meta 定義了role
export const powerRouter =[ 
 { path: '/',redirect:'/red', name: 'index',component: Index,hidden:false,
 children: [
 { path: '/red', name: 'red', component: red,},
 { path: '/yellow', name: 'yellow', component: yellow, meta: {role: 'B'}},
 { path: '/blue', name: 'blue', component: blue, meta: {role: 'C'}}
 ]
 }
];

store/modules/lo

Logins({ commit }, info){
  return new Promise((resolve, reject) => {
  let data={};
  loginByUserInfo.map(function (item) { //獲取所以用戶信息
   if(info.username === item.username || info.pew === item.pew){
   commit('SET_USERNAME',item.username); //將username和role進行存儲
   sessionStorage.setItem('USERNAME', item.username); //存入 session 
   commit('SET_ROLE',item.role);
   sessionStorage.setItem('ROLE', item.role);
   return data={username:item.username,introduce:item.introduce};
   }else{
   return data;
   }
  }); 
  resolve(data);
 }).catch(error => {
  reject(error);
 });
 },
 Roles({ commit }, newrouter){
 return new Promise((resolve, reject) => {
  commit('SET_NEWROUER',newrouter); //存儲最新路由
  resolve(newrouter);
 }).catch(error => {
  reject(error);
 });
 },

gin.js  actions部分

Logins({ commit }, info){
  return new Promise((resolve, reject) => {
  let data={};
  loginByUserInfo.map(function (item) { //獲取所以用戶信息
   if(info.username === item.username || info.pew === item.pew){
   commit('SET_USERNAME',item.username); //將username和role進行存儲
   sessionStorage.setItem('USERNAME', item.username); //存入 session 
   commit('SET_ROLE',item.role);
   sessionStorage.setItem('ROLE', item.role);
   return data={username:item.username,introduce:item.introduce};
   }else{
   return data;
   }
  }); 
  resolve(data);
 }).catch(error => {
  reject(error);
 });
 },
 Roles({ commit }, newrouter){
 return new Promise((resolve, reject) => {
  commit('SET_NEWROUER',newrouter); //存儲最新路由
  resolve(newrouter);
 }).catch(error => {
  reject(error);
 });
 },

main.js

router.beforeEach((to, from, next) => {
 if(store.getters.role){ //判斷role 是否存在
 
 if(store.getters.newrouter.length !== 0){ 
  next() //resolve 鉤子
 }else{
  let newrouter
  if (store.getters.role == 'A') { //判斷權限
  newrouter = powerRouter
  } else {
  let newchildren = powerRouter[0].children.filter(route => {
   if(route.meta){
   if(route.meta.role == store.getters.role){
    return true
   }
   return false
   }else{
   return true
   }
  });
  newrouter = powerRouter
  newrouter[0].children = newchildren
  }
  router.addRoutes(newrouter) //添加動態路由
  store.dispatch('Roles',newrouter).then(res => { 
  next({ ...to })
  }).catch(() => { 

  })
 } 
 }else{
  if (['/login'].indexOf(to.path) !== -1) { 
  next()
 } else {
  next('/login')
 }
 }
})

components/index.vue

// mapGetters 輔助函數僅僅是將 store 中的 getter 映射到局部計算屬性
...mapGetters([
 'newrouter'
 ])

關于如何上手vue vuex vue-rouert后臺的權限路由就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

咸宁市| 招远市| 广东省| 阿鲁科尔沁旗| 五大连池市| 民权县| 彭泽县| 中西区| 广东省| 伊吾县| 玉山县| 台东县| 太仓市| 湘乡市| 永平县| 阜平县| 卓尼县| 镶黄旗| 大石桥市| 安仁县| 广西| 旬邑县| 华池县| 洛川县| 西畴县| 铅山县| 牡丹江市| 娄烦县| 大方县| 永新县| 阿勒泰市| 武山县| 大足县| 鹿邑县| 隆尧县| 怀化市| 迁西县| 南昌县| 吉首市| 马尔康县| 象山县|