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

vue3動態(tài)路由addRoute實例詳解

 更新時間:2023年09月07日 11:07:55   作者:fml海棠  
這篇文章主要介紹了vue3動態(tài)路由addRoute的相關知識,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

Vue2中,有兩種方法實現(xiàn)路由權限動態(tài)渲染:

  router.addRoute(parentOrRoute, route)    //添加單個
  router.addRoutes(routes)                  //添加多個

但在Vue3中,只保留了 addRoute() 方法。

首先,假設路由如下:

const menu = [{
  id: 'system-manage',
  name: 'system-manage',
  path: '/system',
  meta:{
    title: '系統(tǒng)管理',
    icon: 'setting',
  },
  compoent: 'layout',
  children: [
    {
      id: 'role',
      name: 'role',
      path: '/system/role',
      meta:{
        title: '角色管理',
        icon: 'user-filled',
      },
      compoent: 'view/system/role',
      children: []
    }
  ]
}]
// 遞歸替換引入component
function dynamicRouter(routers) {
  const list = []
  routers.forEach((itemRouter,index) => {
    list.push({
      ...itemRouter,
      component: ()=>import(`@/${itemRouter.component}`)
    })
    // 是否存在子集
    if (itemRouter.children && itemRouter.children.length) {
      list[index].children = dynamicRouter(itemRouter.children);
    }
  })
  return list
}
// 防止首次或者刷新界面路由失效
let registerRouteFresh = true
router.beforeEach((to, from, next) => {
  if (registerRouteFresh) {
    // addRoute允許帶children添加,所以循環(huán)第一層即可
    dynamicRouter(menu).forEach((itemRouter) => {
      router.addRoute(itemRouter)
    })
    next({ ...to, replace: true })
    registerRouteFresh = false
  } else {
    next()
  }
})

使用這種拼接的方式會導致全局scss多次注入錯誤,而且需要后臺返回文件路徑。

scss報錯

所以改用以下方式:

// 在本地建一個路由表
const path = [{
  path: '/system/role',
  name: '角色管理',
  component: () => import('@/views/system/role')
}]
function dynamicRouter(routers) {
  const list = []
  routers.forEach((itemRouter,index) => {
    // 從本地找組件
    const authRoute = path.find(i=>i.path==itemRouter.path)
    list.push({
      ...itemRouter,
      component: authRoute?.component || Layout //沒找到則用默認框架組件
    })
    // 是否存在子集
    if (itemRouter.children && itemRouter.children.length) {
      list[index].children = dynamicRouter(itemRouter.children);
    }
  })
  return list
}

如果出現(xiàn) Error: Invalid route component ,看下路徑是否正確,還有 addRoute 里傳的是否是對象,一開始傳了數組導致找了半天(扶額

Invalid route

以上。

到此這篇關于vue3動態(tài)路由addRoute的文章就介紹到這了,更多相關vue3動態(tài)路由addRoute內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • vue3+ant?design的form數組表單校驗方法

    vue3+ant?design的form數組表單校驗方法

    這篇文章主要介紹了vue3+ant?design的form數組表單,如何校驗,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2023-09-09
  • vue 接口請求地址前綴本地開發(fā)和線上開發(fā)設置方式

    vue 接口請求地址前綴本地開發(fā)和線上開發(fā)設置方式

    這篇文章主要介紹了vue 接口請求地址前綴本地開發(fā)和線上開發(fā)設置方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • 詳解Vue中的MVVM原理和實現(xiàn)方法

    詳解Vue中的MVVM原理和實現(xiàn)方法

    這篇文章主要介紹了Vue中的MVVM原理和實現(xiàn)方法,文中講解非常細致,幫助大家更好的理解和學習,感興趣的朋友可以了解下
    2020-07-07
  • Vue中ref、reactive、toRef、toRefs、$refs的基本用法總結

    Vue中ref、reactive、toRef、toRefs、$refs的基本用法總結

    這篇文章主要給大家介紹了關于Vue中ref、reactive、toRef、toRefs、$refs的基本用法,以及他們之家的區(qū)別,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-11-11
  • Vue實現(xiàn)數據請求攔截

    Vue實現(xiàn)數據請求攔截

    這篇文章主要為大家詳細介紹了Vue實現(xiàn)數據請求攔截,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • vue 使用vant插件做tabs切換和無限加載功能的實現(xiàn)

    vue 使用vant插件做tabs切換和無限加載功能的實現(xiàn)

    這篇文章主要介紹了vue 使用vant插件做tabs切換和無限加載功能的實現(xiàn),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • 栽Vue3中傳遞路由參數的三種方式

    栽Vue3中傳遞路由參數的三種方式

    vue 路由傳參的使用場景一般都是應用在父路由跳轉到子路由時,攜帶參數跳轉,傳參方式可劃分為 params 傳參和 query 傳參,本文將給大家介紹如何通過不同方式在 Vue 3 中傳遞路由參數,需要的朋友可以參考下
    2024-07-07
  • 詳解vue項目中如何加載markdown

    詳解vue項目中如何加載markdown

    這篇文章主要為大家詳細介紹了在vue項目中如何加載markdown,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2024-11-11
  • vue移動端項目vant組件庫之tag詳解

    vue移動端項目vant組件庫之tag詳解

    這篇文章主要介紹了vue移動端項目vant組件庫之tag詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • ElementPlus?Table表格實現(xiàn)可編輯單元格

    ElementPlus?Table表格實現(xiàn)可編輯單元格

    本文主要介紹了ElementPlus?Table表格實現(xiàn)可編輯單元格,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2024-12-12

最新評論