欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用vue-element-admin框架從后端動態(tài)獲取菜單功能的實現(xiàn)

 更新時間:2021年04月29日 10:21:06   作者:#Empty  
​ vue-element-admin是一個純前端的框架,左側菜單是根據(jù)路由生成的。實際開發(fā)中經常需要根據(jù)當前登陸人員的信息從后端獲取菜單進行展示,本文將詳細介紹如何實現(xiàn)該功能

2、詳解

​整體思路為:登陸 > 成功后根據(jù)用戶信息獲取菜單 > 根據(jù)菜單生成路由信息

2.1、新增asyncRoutes路由

​在vue-router路徑src\router\index.js中新增asyncRoutes數(shù)組,用來存放后端獲取的菜單對應的路由信息。

export const asyncRoutes = [
  { path: '*', redirect: '/404', hidden: true }
]

constantRoutes和asyncRoutes的區(qū)別

constantRoutes:不需要動態(tài)判斷權限的路由,如登錄頁、404等通用頁面。

asyncRoutes:需求動態(tài)判斷權限并通過addRoutes動態(tài)添加的頁面

2.2、新建permission.js文件

​在vuex路徑src\store\modules\permission.js下新建permission.js文件,該操作為最重要的一步,主要是從后端查詢菜單并生成路由。

import { asyncRoutes, constantRoutes } from '@/router'
import { fetchUserMenuList } from '@/api/user'
import Layout from '@/layout'

/**
 * 靜態(tài)路由懶加載
 * @param view  格式必須為 xxx/xxx 開頭不要加斜杠
 * @returns 
 */
export const loadView = (view) => {
  return (resolve) => require([`@/views/${view}.vue`], resolve)
}

/**
 * 把從后端查詢的菜單數(shù)據(jù)拼裝成路由格式的數(shù)據(jù)
 * @param routes
 * @param data 后端返回的菜單數(shù)據(jù)
 */
export function generaMenu(routes, data) {
  data.forEach(item => {
    const menu = {
      path: item.url, 
      component: item.component === '#' ? Layout : loadView(item.component), 
      hidden: item.status === 0, // 狀態(tài)為0的隱藏
      redirect: item.redirect,
      children: [],
      name: item.code,
      meta: item.meta
    }

    if (item.children) {
      generaMenu(menu.children, item.children)
    }
    routes.push(menu)
  })
  return routes
}

const state = {
  routes: [],
  addRoutes: []
}

const mutations = {
  SET_ROUTES: (state, routes) => {
    state.addRoutes = routes
    // 拼接靜態(tài)路由和動態(tài)路由
    state.routes = constantRoutes.concat(routes)
  }
}

const actions = {
  generateRoutes({ commit }, token) {
    return new Promise(resolve => {
      // 通過token從后端獲取用戶菜單,并加入全局狀態(tài)
      fetchUserMenuList(token).then(res => {
        const menuData = Object.assign([], res.data)
        const tempAsyncRoutes = Object.assign([], asyncRoutes)
        const accessedRoutes = generaMenu(tempAsyncRoutes, menuData)

        commit('SET_ROUTES', accessedRoutes)
        resolve(accessedRoutes)
      }).catch(error => {
        console.log(error)
      })
    })
  }
}

export default {
  namespaced: true,
  state,
  mutations,
  actions
}

2.3、在vuex中注冊permission模塊

​如果使用的是vue-element-admin請?zhí)^此步,因為它在src\store\index.js中自動注冊了src\store\modules下的所有模塊。如果你使用的是vue-element-template,可以參考admin,將index.js文件改造一下,也可以手動import一下。

import Vue from 'vue'
import Vuex from 'vuex'
import getters from './getters'

Vue.use(Vuex)

// https://webpack.js.org/guides/dependency-management/#requirecontext
const modulesFiles = require.context('./modules', true, /\.js$/)

// you do not need `import app from './modules/app'`
// it will auto require all vuex module from modules file
const modules = modulesFiles.keys().reduce((modules, modulePath) => {
  // set './app.js' => 'app'
  const moduleName = modulePath.replace(/^\.\/(.*)\.\w+$/, '$1')
  const value = modulesFiles(modulePath)
  modules[moduleName] = value.default
  return modules
}, {})

const store = new Vuex.Store({
  modules,
  getters
})

export default store

2.4、在getters中增加路由狀態(tài)

​在vuex路徑src\store\getters.js添加menusRoutes狀態(tài)

menusRoutes: state => state.permission.routes

2.5、修改菜單生成數(shù)據(jù)來源

​在路徑src\layout\components\Sidebar\index.vue修改routes數(shù)據(jù)來源,原來數(shù)據(jù)源是路由,改為從vuex中獲取。

routes() {
      // return this.$router.options.routes
      return this.$store.getters.menusRoutes
    },

​至此,從后端獲取菜單數(shù)據(jù)到頁面展示的邏輯已經完畢,下面開始在登陸后進行調用。

2.6、登陸后獲取菜單

​在vuex路徑src\store\modules\user.js的login方法中,加入登陸成功通過token獲取菜單生成路由邏輯。

 // 獲取菜單,調用其他文件中actions時必須加 { root: true }
          dispatch('permission/generateRoutes', data, { root: true }).then((accessRoutes) => {
            router.addRoutes(accessRoutes)
          })

2.7、解決刷新后頁面空白

​以上內容已經可以實現(xiàn)登陸后展示左側菜單功能,但是會發(fā)現(xiàn)每次刷新頁面后,頁面都會變空白。這是因為在頁面刷新時,會重新加載vue實例,vuex的store中的數(shù)據(jù)會被重新賦值,導致我們存在vuex中的路由信息被清空。

​在src\permission.js中增加重新獲取路由代碼。

const accessRoutes = await store.dispatch('permission/generateRoutes', store.getters.token)
          router.addRoutes(accessRoutes)
          next({ ...to, replace: true })

3、總結

​至此根據(jù)用戶信息動態(tài)獲取菜單內容已經全部完成。

到此這篇關于使用vue-element-admin框架從后端動態(tài)獲取菜單的文章就介紹到這了,更多相關vue-element-admin動態(tài)獲取菜單內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • vue日期選擇框之時間范圍的使用介紹

    vue日期選擇框之時間范圍的使用介紹

    這篇文章主要介紹了vue日期選擇框之時間范圍的使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Vue實現(xiàn)模糊查詢filter()實例詳解

    Vue實現(xiàn)模糊查詢filter()實例詳解

    因為近日在學習并使用VUE,客戶有一個要求,要輸入框可模糊查詢并帶有下拉提示的應用,數(shù)據(jù)從接口取,下面這篇文章主要給大家介紹了關于Vue實現(xiàn)模糊查詢filter()的相關資料,需要的朋友可以參考下
    2023-04-04
  • Vue組件之極簡的地址選擇器的實現(xiàn)

    Vue組件之極簡的地址選擇器的實現(xiàn)

    這篇文章主要介紹了Vue組件之極簡的地址選擇器的實現(xiàn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • vue使用vue-draggable的全過程

    vue使用vue-draggable的全過程

    這篇文章主要介紹了vue使用vue-draggable的全過程,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue使用file-saver插件保存各種格式文件方式

    vue使用file-saver插件保存各種格式文件方式

    這篇文章主要介紹了vue使用file-saver插件保存各種格式文件方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-07-07
  • 在Vue mounted方法中使用data變量詳解

    在Vue mounted方法中使用data變量詳解

    今天小編就為大家分享一篇在Vue mounted方法中使用data變量詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • vue單頁應用加百度統(tǒng)計代碼(親測有效)

    vue單頁應用加百度統(tǒng)計代碼(親測有效)

    這篇文章主要介紹了vue單頁應用加百度統(tǒng)計代碼的解決方法,需要的朋友參考下吧
    2018-01-01
  • vue.js實現(xiàn)點擊圖標放大離開時縮小的代碼

    vue.js實現(xiàn)點擊圖標放大離開時縮小的代碼

    這篇文章主要介紹了vue.js實現(xiàn)點擊圖標放大離開時縮小,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01
  • Vue實現(xiàn)單行刪除與批量刪除

    Vue實現(xiàn)單行刪除與批量刪除

    這篇文章主要介紹了Vue實現(xiàn)單行刪除與批量刪除,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • 8個非常實用的Vue自定義指令

    8個非常實用的Vue自定義指令

    這篇文章主要介紹了8個非常實用的Vue自定義指令,幫助大家更好的理解和使用vue,感興趣的朋友可以了解下
    2020-12-12

最新評論