日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > vue >内容正文

vue

vue require动态路径图片报错_Vue 动态生成路由结构

發布時間:2024/9/27 vue 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 vue require动态路径图片报错_Vue 动态生成路由结构 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

通常我們比較常用的vue組件加載方式就是通過import引入文件,如:路由懶加載 、靜態的import。

一般情況下還是推薦使用import方式引入的,因為這更容易從Tree_shaking 及一些分析工具中受益。

在一些比較特殊的場景,比如:

需要根據后臺的菜單配置, 動態生成Vue路由。

假如后臺返回了以下JSON數據結構

[ { "alwaysShow":true, "children":[ { "alwaysShow":false, "component":"OA/AskForLeaveManagement/AskForLeaveManagement", "hidden":false, "meta":{ "icon":"", "id":2004, "title":"請假管理" }, "name":"AskForLeaveManagement", "path":"askForLeaveManagement", "redirect":"" }, { "alwaysShow":false, "children":[ ], "component":"OA/WorkOvertimeManagement/WorkOvertimeManagement", "hidden":false, "meta":{ "icon":"", "id":3687, "title":"加班管理" }, "name":"WorkOvertimeManagement", "path":"workOvertimeManagement", "redirect":"" }, ], "component":"Layout", "hidden":false, "meta":{ "icon":"dashboard", "id":2001, "title":"辦公管理" }, "name":"Oa", "path":"/oa", "redirect":"noRedirect" }, { "alwaysShow":false, "children":[ ], "component":"Layout", "hidden":true, "meta":{ "icon":"", "id":3618, "title":"首頁" }, "name":"Dashboard", "path":"/dashboard", "redirect":"" }]

一般vue路由會類似這樣定義

{ path: '/redirect', component: Layout, hidden: true, children: [ { path: '/redirect/:path*', component: () => import('@/views/redirect/index'), }, ], }, { path: '/login', component: () => import('@/views/login/index'), hidden: true, }, { path: '/auth-redirect', component: () => import('@/views/login/auth-redirect'), hidden: true, },

從JSON數據結構轉換到vue路由定義,我們只需要進行遞歸處理就好 。

但這里面我們需要重點關注 component的實現

component:()=>import('@/views/redirect/index'),

假如我們繼續通過import 引入組件的方式,在我們進行遞歸處理進行動態賦值時,比如

component:()=>import('@/views/' + path ),

會發現 import 其實是不支持動態變量的,所以我們通過這種方式是無法正確找到路由的


require(AMD版本)

針對上面使用 import 出現無法正確找到路由的情況,我們可以通過這種方式處理。

定義loadComponent函數,將后臺返回內容處理后, 再賦值給 component

const loadComponent = (path) => { // 路由懶加載 return (resolve) => require(['../../components' + path], resolve)}

假如想加載不同文件夾下的vue文件, 我們需要聲明文件目錄的前綴, 不然也會報錯的

export const loadViews = (view) => { // 路由懶加載 return (resolve) => require(['../../views/' + view], resolve)}export const loadComponents = (path) => { // 路由懶加載 return (resolve) => require(['../../components' + path], resolve)}

通過這種方式改造后,Vue路由可以完全的通過后臺進行控制, 如: 公用組件的參數設置、動態設置按鈕關聯組件等等

假如想通過某個按鈕點擊后加載某個vue組件, 可以封裝上面的方法, 大致如下

getComponents(value) { return new Promise((r, j) => { const url = value.replace('', '/') if (url.includes('components')) { const path = url.replace('components', '') require(['@/components' + path], function(v) { r(v) }).catch(e => { console.log('error', e) j(new Error(`無法找到組件,請確認地址是否正確`)) }) } else { require(['@/views/' + url], function(v) { r(v) }).catch(e => { console.log('error', e) j(new Error(`無法找到組件,請確認地址是否正確`)) }) } }) },

有哪里寫的不好或者想討論的可以在下方 評論區跟我討論噢

總結

以上是生活随笔為你收集整理的vue require动态路径图片报错_Vue 动态生成路由结构的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 四虎最新域名 | 日韩精品在线免费 | 亚洲精品97久久中文字幕无码 | 国产二区av| 成人黄色短片 | 伊人久久久久久久久久久久 | 久久久无码18禁高潮喷水 | 国产玖玖在线 | 影音先锋中文字幕一区二区 | 国产一区二区免费在线 | 99热一区二区 | 综合网亚洲 | 免费看国产片在线观看 | 亚洲女人被黑人巨大进入 | 久久精品视频99 | 丰满人妻一区二区三区53视频 | 中文字幕精品在线 | 欧美精品国产动漫 | 精品中文字幕在线 | 亚洲美女在线视频 | 精品久久久蜜桃 | 在线观看毛片av | 亚洲永久精品一区二区 | 成人午夜免费福利 | 网站在线免费观看 | 最新日韩在线 | 久久伊人网站 | 日韩精品中文字幕在线 | 国产jk精品白丝av在线观看 | 国产精品黑人一区二区三区 | youjizz韩国 | 天天干夜夜草 | 看看黄色片 | 国产一区二区在线播放视频 | 久久亚洲私人国产精品va | 日本老太婆做爰视频 | 秋霞欧美一区二区三区视频免费 | 欧洲高潮三级做爰 | 国产又粗又猛视频免费 | 麻豆成人精品国产免费 | 99人妻碰碰碰久久久久禁片 | 欧美黄色片 | 国产精品自拍偷拍 | 免费黄色小视频网站 | 精品国产一区一区二区三亚瑟 | 精品国产一二 | 中文字幕乱码av | 中国女人特级毛片 | 在线观看日韩一区二区 | 亚洲欧洲精品一区 | 人超碰| 99视频久 | 亚洲精品综合在线 | 人人爽人人干 | 在线亚洲网站 | 国产精品久久久久久久一区二区 | 人人草人人草 | 超碰三级| 亚洲一区二区三区加勒比 | 性欧美巨大 | 啪啪日韩 | 亚洲午夜久久 | 欧美寡妇性猛交ⅹxxx | 成人av一区二区在线观看 | av黄色在线看 | 色偷偷网站 | 性欧美18一19内谢 | 日日摸天天添天天添破 | 亚洲三级在线观看 | 日韩欧美aⅴ综合网站发布 国产成人一区二区三区小说 | 欧美日韩人妻一区二区 | 亚洲va久久久噜噜噜无码久久 | 少妇系列在线观看 | 午夜影院免费体验区 | wwwxxxx在线观看 | 你操综合 | 电影《两个尼姑》免费播放 | 操处女逼视频 | 精品一区在线视频 | 久久香蕉精品 | 三级网站免费 | 黄色资源在线播放 | 奇米影视四色7777 | 精品国产a线一区二区三区东京热 | 久久成人国产 | 一区二区三区精品在线 | 亚洲午夜片 | 狠狠搞狠狠干 | 韩日a级片| 蜜臀人妻四季av一区二区不卡 | 爱爱免费小视频 | 啪视频网站 | 岛国精品一区二区三区 | 婷婷久久久久久 | 久视频在线观看 | 国产美女主播在线观看 | 精东传媒在线观看 | 国产香蕉97碰碰碰视频在线观看 | 精品精品精品 |