日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Vue Router根據后臺數據加載不同的組件實現

瀏覽:22日期:2023-02-16 10:20:50
目錄實際項目中遇到的需求有一些不好的實現方式個人感覺比較好的實現方式功能已實現,但我又開始了新的思考最終方案——高階組件實際項目中遇到的需求

同一個鏈接需要加載不同的頁面組件。根據用戶所購買服務的不同,有不同的頁面展現。

有一些不好的實現方式 直接把這幾個組件寫在同一個組件下,通過v-if去判斷。如果這么做的話,甚至可以不使用vue-router,直接把所有組件,都寫在一個文件里面,全部通過v-if判斷,也是可行的。(前提是幾萬行代碼一起,你不嫌麻煩的話) 在渲染這個鏈接的時候,直接去請求后臺的數據,通過數據渲染不同的鏈接。(理論上是可行的,但如果用戶沒有用這個功能,這些鏈接每次都提前取了后臺數據;另外如果用戶知道了鏈接,直接訪問鏈接,還是需要邏輯去判斷用戶該看到哪個頁面) 通過調用router.beforeEach,對每個路由進行攔截,當路由為我們指定的路由時,請求后臺數據,動態跳轉頁面。(功能是可以完成,但實際上,這只是整個系統的一小塊功能,不應該侵入整個路由系統,如果每個業務頁面,都寫在全局路由系統,也會導致路由的邏輯過于復雜) 個人感覺比較好的實現方式

在配置路由的地方獲取服務器數據動態加載對應的組件

{ path: ’shopKPI’, // 如果提前把后臺數據存到store里面,在這里訪問store數據,可以直接判斷出來 // 但這種特定業務頁面的數據放全局store,其他地方也不用,實在沒有必要 component: () => import(’@/views/store/dataVersion’), name: ’store_KPI’, menuName: ’店鋪參謀’, meta: { codes: [’storeProduct.detail’] }}

理想很美好,現實的情況是,component接收的這個方法必須要同步的返回一個promise。

這時候我想到了上面不好的實現方式1,稍微加以改造

<!-- ChooseShopKPI.vue --><template> <dataVersion v-if='!useNewShopKPI' /> <ShopKPI v-else /></template><script>import { get } from ’lodash’;import { getStoreReportFormVersion } from ’@/api/store’;import dataVersion from ’./dataVersion’;import ShopKPI from ’./ShopKPI’;export default { name: ’ChooseShopKPI’, components: { dataVersion, ShopKPI, }, data() { return { useNewShopKPI: false }; }, created() { getStoreReportFormVersion().then((res) => { if (get(res, ’data.data.new’)) {this.useNewShopKPI = true; } }); },};</script><style lang='css' scoped></style>

把路由渲染對應的頁面,改為渲染這個中間頁面ChooseShopKPI

{ path: ’shopKPI’, // 如果提前把后臺數據取到,在這里訪問store數據,可以直接判斷出來 // 但這種特定業務頁面的數據放全局store,其他地方也不用,實在沒有必要- component: () => import(’@/views/store/dataVersion’),+ component: () => import(’@/views/store/ChooseShopKPI’), name: ’store_KPI’, menuName: ’店鋪參謀’, meta: { codes: [’storeProduct.detail’] }}

這樣就實現了我們期望的功能。

功能已實現,但我又開始了新的思考

這種方式雖然很好的解決了動態加載頁面組件的問題。但也產生了一些小問題。

如果這種通過服務器加載數據的頁面后續增加的話,會出現多個ChooseXXX的中間頁面。 這種中間頁面,實際上是做了二次路由,不熟悉邏輯的開發人員可能并不清楚這里面的頁面跳轉邏輯,增加了理解成本。最終方案——高階組件

通過對ChooseXXX進行抽象,改造為DynamicLoadComponent

<!-- DynamicLoadComponent.vue --><template> <component :is='comp' /></template><script>export default { name: ’DynamicLoadComponent’, props: { renderComponent: { type: Promise, }, }, data() { return { comp: () => this.renderComponent } }, mounted() {},};</script><style lang='css' scoped></style>

直接在路由的配置中獲取后臺數據,并進行路由的分發。這樣路由邏輯都集中在路由配置文件中,沒有二次路由。維護起來不會頭疼腦脹。

DynamicLoadComponent組件也得以復用,后續新增判斷后臺數據加載頁面的路由配置,都可以導向這個中間組件。

{ path: ’shopKPI’, component: () => import(’@/views/store/components/DynamicLoadComponent’), name: ’store_KPI’, menuName: ’店鋪參謀’, meta: { codes: [’storeProduct:detail’], }, props: (route) => ({ renderComponent: new Promise((resolve, reject) => { getStoreReportFormVersion().then((responseData) => { const useNewShopKPI = get(responseData, ’data.data.shop_do’); const useOldShopKPI = get( responseData, ’data.data.store_data_show’ ); if (useNewShopKPI) { resolve(import(’@/views/store/ShopKPI’)); } else if (useOldShopKPI) { resolve(import(’@/views/store/dataVersion’)); } else { resolve(import(’@/views/store/ShopKPI/NoKPIService’)); }}).catch(reject); }), })}

查看在線小例子(只支持chrome)https://stackblitz.com/edit/vuejs-starter-jsefwq?file=index.js

到此這篇關于Vue Router根據后臺數據加載不同的組件實現的文章就介紹到這了,更多相關Vue Router后臺數據加載不同的組件 內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美手机在线| 激情91久久| 日韩精品一级中文字幕精品视频免费观看 | 国产精品自在| 久久亚洲人体| 久久精品国内一区二区三区水蜜桃| 激情欧美一区二区三区| 蜜臀av一区二区三区| 欧美亚洲人成在线| 91偷拍一区二区三区精品| 免费不卡中文字幕在线| 亚洲无线观看| 国产乱人伦精品一区| 国产第一亚洲| 亚洲专区一区| 久久超级碰碰| 亚洲黄色影院| 国产精品欧美一区二区三区不卡| 日韩电影二区| 亚洲精品无吗| 综合日韩av| 一本一道久久a久久| 久久精品免费看| 欧美特黄a级高清免费大片a级| 91av一区| 天堂网av成人| 日韩动漫一区| 97在线精品| 亚州精品视频| 成人午夜精品| 午夜性色一区二区三区免费视频| 欧美a一区二区| 国产精品美女久久久| 捆绑调教美女网站视频一区| 亚洲综合日本| 97人人精品| 日韩福利在线观看| 性欧美xxxx免费岛国不卡电影| 欧美一级久久| 免费观看不卡av| 精品国产亚洲一区二区在线观看| 久久亚洲电影| 亚洲天堂资源| 日本麻豆一区二区三区视频| 亚洲午夜av| 久久精品伊人| 在线精品观看| 成人免费电影网址| 麻豆91在线播放| 日韩中文一区二区| 婷婷国产精品| 亚洲女同av| 久久婷婷国产| 国产日韩欧美一区在线| 午夜在线播放视频欧美| 久久久一本精品| 欧美激情精品| 最新国产精品视频| 欧美日韩视频| 欧美日韩精品免费观看视欧美高清免费大片 | 色综合视频一区二区三区日韩| 欧美三级网址| 精品精品国产三级a∨在线| 91亚洲精品在看在线观看高清| 激情久久中文字幕| 免费一二一二在线视频| 精品三区视频| 国产午夜一区| 国产亚洲精品美女久久| 亚洲一区欧美| 免费的成人av| 麻豆成人在线| 爽好久久久欧美精品| 激情综合亚洲| 国产综合精品| 日本久久成人网| 精品欧美一区二区三区在线观看| 精品国产欧美日韩| 九九99久久精品在免费线bt| 欧美久久久网站| 欧美视频久久| 久久国产生活片100| 久久精品99国产精品日本| 日韩精品一区二区三区av| 中文字幕日韩亚洲| 中文一区一区三区免费在线观 | 国语对白精品一区二区| 国产欧美自拍一区| 欧美偷窥清纯综合图区| 欧美日韩一区二区三区不卡视频| 日韩激情网站| 国产乱人伦精品一区| 日本欧美韩国一区三区| 欧美一区二区三区久久精品| 国产午夜精品一区在线观看| 国产精品欧美在线观看| 久久久精品国产**网站| 日韩综合在线| 欧美+日本+国产+在线a∨观看| 女人天堂亚洲aⅴ在线观看| 午夜一区在线| 日本成人在线不卡视频| 18国产精品| 精品一区二区三区免费看| 日本久久黄色| 日韩成人综合| av一区二区高清| 国产模特精品视频久久久久| 日韩在线卡一卡二| 日本91福利区| 精品精品久久| 蜜桃视频欧美| 日本一区二区中文字幕| 国产精品成人自拍| 精品国产午夜肉伦伦影院| 欧洲亚洲一区二区三区| 亚洲免费影视| 国产日韩三级| 啪啪国产精品| 亚洲精品字幕| 国际精品欧美精品| 亚洲手机在线| 亚洲区国产区| 国模精品一区| 99在线|亚洲一区二区| 日韩av三区| 一本大道色婷婷在线| 性欧美长视频| 国产精品观看| 亚洲国产专区| 91成人小视频| 日韩美女一区二区三区在线观看| 日韩一区二区久久| 久久激情av| 99国产精品免费视频观看| 丝袜亚洲另类欧美| 麻豆国产欧美一区二区三区| 日韩欧美精品一区| 蜜桃视频第一区免费观看| 精品久久网站| 制服诱惑一区二区| 欧美视频久久| 亚洲v在线看| 青青青国产精品| 国产一区亚洲| 国产美女视频一区二区| 99久久婷婷这里只有精品| 日本中文字幕一区二区视频| 欧美13videosex性极品| 日本午夜精品| 99久久夜色精品国产亚洲1000部| 日韩在线电影| 国产精品成久久久久| 视频一区二区不卡| 9999国产精品| 欧美影院精品| 国产精品视区| 日韩中文视频| 麻豆一区二区在线| 日韩中文字幕不卡| 日韩在线高清| 免费在线成人| 日韩精品视频在线看| 欧美日韩精品免费观看视频完整| 麻豆精品久久久| 日本不卡的三区四区五区| 久久婷婷久久| 久久只有精品| 91嫩草精品| 免费久久精品视频| 久久亚洲精品中文字幕蜜潮电影| 国产精品蜜月aⅴ在线| 首页欧美精品中文字幕| 欧洲精品一区二区三区| 国产精品多人| 日韩精品视频一区二区三区| 国产精品美女久久久| 成人羞羞在线观看网站| 国产精品综合| 日韩精品亚洲专区在线观看| 国产亚洲在线| 女人av一区| 中文在线а√天堂| 另类综合日韩欧美亚洲| 久久激情av| 欧美亚洲二区| 欧美在线首页| 久久精品av麻豆的观看方式| 亚洲久久一区| 男女激情视频一区| 日韩一区二区久久| 不卡一区2区| 精品中文字幕一区二区三区av| 日韩免费福利视频| 亚洲国产福利| 伊人网在线播放| 日韩欧美一区二区三区免费看| 精品九九久久| 福利一区在线| 在线中文字幕播放|