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

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

vue 項目代碼拆分的方案

瀏覽:24日期:2022-10-02 11:50:08
背景

由于之前的數據庫防火墻產品與數據庫審計產品使用的是同一套代碼,隨著兩個產品功能的差異越來越大,代碼的冗余度和偶合度越來越高,為了便于后期維護以及添加新功能,所以基于原來的項目代碼,進行了代碼結構拆分。

注意:本次拆分只拆分了可以拆分的部分,有的模塊例如:規則、關于我們,是沒有進行拆分的,一是有的模塊很簡單,沒必要拆分;二是有的模塊原先寫得代碼偶合太嚴重,無法拆分,如果要拆分,需要花費大量精力去梳理代碼,同時還要后端配合拆分。

目的

將此次代碼拆分方案記錄下來,便于后來的開發人員快速熟悉項目結構。

拆分前流程設計

vue 項目代碼拆分的方案

項目拆分前,區分數審和防火墻功能的流程如上圖所示。

訪問系統時,先加載入口文件 main.js,然后加載登錄頁 login.vue,加載登錄頁的同時獲取產品模式并保存到 session.storage.platformType 中,接著用戶登錄系統進入具體頁面,該頁面同時包含了數審和防火墻的功能,根據 session.storage.platformType 保存的值來判斷,具體顯示哪個功能。

目錄結構設計

vue 項目代碼拆分的方案

項目拆分前的目錄結構如上圖所示。

該目錄結構是初始化一個 Vue 項目時的基本目錄,根據目錄結構,基本上看不出該項目包含了兩個不同的產品,也不知道不同產品模式下會加載哪一部分文件,結構不清晰。

存在的問題

通過分析,可以發現當前的系統流程和目錄結構是存在很多問題的,大概總結下:

加載登錄頁的時候才獲取產品模式,如果登錄頁加載完成,而產品模式還未獲取或者獲取不到,那么登錄頁顯示的產品信息有可能是錯誤的; 每次進入一個具體頁面,如果同時包含了數審和防火墻的功能,都要重新判斷一次,當前的功能是數審的還是防火墻的; 目錄結構不清晰,不清楚哪些模塊是公共模塊,哪些是數審獨有的模塊,哪些是防火墻獨有的模塊; 可維護性和可擴展性差。數審的代碼和防火墻的代碼混在一個文件內,改代碼的時候需要重頭看一遍才知道哪塊代碼屬于數審,哪塊代碼屬于防火墻。如果想要添加一個功能,還得繼續加邏輯判斷,代碼越來越臃腫; 業務邏輯混亂,與后端通信使用了同一個接口。 拆分后流程設計

vue 項目代碼拆分的方案

項目拆分后,區分數審和防火墻功能的流程如上圖所示。

訪問系統時,先加載入口文件 main.js,該文件中寫了路由攔截相關的邏輯,在路由攔截時,如果沒有產品模式,則要先獲取產品模式,否則會被攔截,進不去系統。獲取產品模式后,根據當前產品模式,會注冊對應的登錄頁、路由配置、接口請求等。當注冊完畢后,每次訪問具體的頁面,都應該是獨立的模塊了。

目錄結構設計

vue 項目代碼拆分的方案

vue 項目代碼拆分的方案

項目拆分后的目錄結構如上兩個圖所示。

該目錄結構經過拆分,已經可以清晰地看到不同產品之間分離出來的文件了,從入口文件開始,經過路由攔截后,會加載指定的登錄頁,然后把對應產品需要的文件合并到公共文件中。比如:http 請求、路由配置等。最終結果,程序只會把需要的文件加載進去。

解決的問題

經過重新設計,解決了當前項目存在的一些問題:

在加載登錄頁之前,通過路由攔截,必須先獲取產品模式,才能進入系統,登錄頁是在獲取到產品模式之后才加載的,不會出現產品信息顯示錯誤的問題; 只有在第一次進入系統或刷新頁面的時候,才會重新獲取產品模式,合并產品模式對應的文件,合并的文件是拆分后的文件,不需要在文件內再次判斷該有數審的功能還是防火墻的功能。 目錄結構清晰,防火墻相關的功能模塊文件都放在 views-fw 文件夾內。 提高了項目的可維護性和可擴展性,降低了代碼的偶合度。數審的代碼和防火墻的代碼基本已經拆分開,如果想要添加一個防火墻的功能,只需要在防火墻相關的文件夾內新增對應功能模塊的文件即可。 業務邏輯清晰,與后端通信使用的是不同的接口,公共模塊使用的接口按原來的不變,數審獨有的接口在 url 前面增加了 audit 前綴,防火墻獨有的接口在 url 前面增加了 firewall 前綴。 關鍵代碼

/** * @Name: main.js * @Author: cqfeng * @Description: 項目入口 js 文件 * @MainFunction: 引入和注冊一些全局資源 **///...省略的代碼...// 路由攔截,使用全局導航守衛beforeEachrouter.beforeEach(async (to, from, next) => { // 如果沒有產品模式,先獲取產品模式 if (!store.state.productMode.productMode) { await store.dispatch(’productMode/SET_PRODUCT_MODE’); }//...省略的代碼...

/** * @Name: product-mode.js * @Author: cqfeng * @Description: 產品模式相關邏輯處理文件 * @MainFunction: 保存當前產品模式,根據不同產品模式配置 產品登錄頁、http 請求 等資源 **/import Vue from ’vue’;import portService from ’@/assets/js/service/http/http’; // axios請求import router from ’@/router/index’; // 默認路由配置,動態路由配置import httpAAS from ’@/assets/js/service/http/http-aas’; // 數審獨有的 http 請求import httpFW from ’@/assets/js/service/http/http-fw’; // 防火墻獨有的 http 請求import globalConstant from ’@/assets/js/const/global-constant’; // 項目全局常量export default { namespaced: true, state: { productMode: ’’, // 產品模式,進入系統或刷新頁面時獲取 }, mutations: { // 修改產品模式 changeProductMode: function (state, value) { state.productMode = value; }, }, actions: { async SET_PRODUCT_MODE({ commit, state }) { let res = await portService.getProductMode(); if (res.data.code === 0) { commit(’changeProductMode’, res.data.data.productMode); } // 如果是數審產品 if (state.productMode === globalConstant.COMMON.AAS) { // 設置產品登錄頁 router.addRoutes([ { path: ’/login’, name: ’login’, component: resolve => { require([’@/views/login.vue’], resolve); }, } ]); // 合并 http 請求,掛載到 Vue 原型上 Vue.prototype.portService = Object.assign(portService, httpAAS); } // 如果是防火墻產品 else if (state.productMode === globalConstant.COMMON.DBSG) { // 設置產品登錄頁 router.addRoutes([ { path: ’/login’, name: ’login’, component: resolve => { require([’@/views/views-fw/login.vue’], resolve); }, } ]); // 合并 http 請求,掛載到 Vue 原型上 Vue.prototype.portService = Object.assign(portService, httpFW); } } }};總結

經過拆分,數審和防火墻的代碼目錄已經算是基本分開了,這個過程花費的力氣也很大,也引發了我的一些思考,一套代碼多個項目的這種方案是否算好的方案,還有沒有其他更好的方案。如果項目一開始,就按照一套代碼多個項目的設計來開發,會不會后期的維護成本會低一些?這些問題我也沒有答案,希望后來者能夠繼承歷史經驗,更好地開發出優秀的項目。

其他實現方式

起初設計拆分方案的時候,有兩種方案,一種是通過獲取產品模式動態改變當前產品功能,一種是在打包時通過打包參數打包指定產品包。最終的方案是選擇第一種。但是,在這個過程中也參考了一些網上的實現方案,這里列出來方便以后需要用到進行參考。

//www.jb51.net/article/188869.htm

//www.jb51.net/article/207835.htm

以上就是vue 項目代碼拆分的方案的詳細內容,更多關于vue 項目代碼拆分的資料請關注好吧啦網其它相關文章!

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美日韩1区| 国产精品欧美大片| 国产精品久久| 日韩av电影一区| 青青在线精品| 日本午夜精品久久久久| 亚洲人成高清| 亚洲aa在线| 日韩精品a在线观看91| 涩涩涩久久久成人精品| 日韩高清在线不卡| 日韩高清电影一区| 日韩av电影一区| 日本成人中文字幕在线视频| 亚洲综合小说| 欧美影院精品| 久久不见久久见国语| 韩国一区二区三区视频| 久久uomeier| 九九综合在线| 亚洲三级精品| 国产伦理一区| 成人av三级| 欧美理论视频| 亚洲免费专区| 国产精品久久久久久久久免费高清 | 亚洲欧美日韩国产综合精品二区| 国产精品a级| 亚洲黄色免费av| 好看不卡的中文字幕| 蜜臀久久99精品久久久久宅男| 日本99精品| 精品一区二区三区亚洲| 婷婷激情一区| 蜜桃视频一区二区三区| 国产精品1luya在线播放| 日韩国产一区| 中文一区一区三区免费在线观 | 午夜免费一区| 日本成人在线不卡视频| 免费在线亚洲| 不卡中文字幕| 国产欧美另类| 久久亚洲国产| 日韩中文字幕在线一区| 精品国产午夜肉伦伦影院| 91成人超碰| 国产精品99精品一区二区三区∴| 在线日韩中文| 国产精品hd| 在线一区视频| 国产精品久久久久av蜜臀 | 美女视频免费精品| 偷拍欧美精品| 国产精品一区二区99| 999久久久国产精品| 日本aⅴ亚洲精品中文乱码| 亚洲性色av| 久久国产人妖系列| 尹人成人综合网| 欧美aⅴ一区二区三区视频| 国产综合精品| 国产精品地址| 免费日韩av片| 日韩a一区二区| 亚洲一级淫片| 日韩精品一区二区三区免费观影| 蜜桃av一区二区三区电影| 日韩av片子| 亚洲精品激情| 久久视频精品| 国产极品一区| 日韩中文欧美在线| av日韩中文| 青青草国产成人99久久| 国产韩日影视精品| 91一区二区三区四区| 视频精品一区| 激情综合在线| 成人在线丰满少妇av| 欧美日本不卡高清| 老司机精品久久| 国产传媒在线观看| 日韩不卡手机在线v区| 亚洲国产综合在线看不卡| 另类小说一区二区三区| 亚洲三区欧美一区国产二区| 国产一区日韩欧美| 成人精品久久| 国产精品99久久免费观看| 久久99伊人| 久久久水蜜桃av免费网站| 美腿丝袜亚洲一区| 久久精品凹凸全集| 亚洲不卡视频| 免费日韩av| 婷婷色综合网| 天堂8中文在线最新版在线| 国产精品二区影院| 91精品国产自产观看在线| 国产精品日本| 亚洲成人精选| 免费污视频在线一区| 97精品国产| 鲁大师精品99久久久| 国产精品视频一区二区三区四蜜臂 | 老色鬼精品视频在线观看播放| 1024精品一区二区三区| 精品午夜av| 欧美a级一区二区| 国产精品一区三区在线观看| 日本成人在线网站| 日韩精品亚洲专区| 日韩中文字幕| 亚洲精品精选| 亚洲精品激情| 亚洲一二av| 一区二区三区四区日韩| 国产一区二区精品| 亚洲欧美日韩视频二区| 一区在线视频观看| 黑丝一区二区三区| 麻豆精品91| 午夜久久av | 国产精品自拍区| 国产极品一区| 福利一区二区免费视频| 不卡专区在线| 亚洲性色av| 国产真实久久| 亚洲激情黄色| 国产一区91| 亚洲v天堂v手机在线| 日韩区欧美区| 久久精品99久久久| 免费视频一区二区三区在线观看 | 国产欧美一区二区三区精品酒店| 捆绑调教日本一区二区三区| 亚洲性色av| 91成人精品| 亚洲日本欧美| 国产视频一区二区在线播放| 久久超级碰碰| av综合电影网站| 欧美午夜不卡| 蜜臀av性久久久久蜜臀aⅴ四虎| 日韩精品免费观看视频| 国产乱人伦丫前精品视频 | 在线看片福利| 国产伊人精品| 亚洲香蕉视频| 国产日韩一区| 三上悠亚国产精品一区二区三区| 激情五月综合| 亚久久调教视频| 久久亚洲精品中文字幕| 电影91久久久| 国产99亚洲| 久久不射网站| 国产乱码精品一区二区三区亚洲人| yellow在线观看网址| 久久夜色精品| 久久97久久97精品免视看秋霞| 久久久天天操| 亚洲97av| 成人午夜毛片| 丝袜美腿亚洲色图| 麻豆国产精品一区二区三区| 婷婷成人基地| 国产精品一区二区三区www| 日韩精品欧美激情一区二区| 在线免费观看亚洲| 久久字幕精品一区| 欧美日一区二区| 色综合视频一区二区三区日韩| 麻豆中文一区二区| 亚洲欧洲另类| 国产成人精选| 蜜桃久久av一区| 91视频一区| 亚洲精品黄色| se01亚洲视频| 青青草国产成人99久久| 久久人人97超碰国产公开结果| 青草综合视频| 一区二区三区视频免费观看 | 亚洲精品护士| 国产伦久视频在线观看| 免费人成精品欧美精品| 久久中文字幕一区二区三区| 亚洲欧美不卡| 久久毛片亚洲| 欧美偷窥清纯综合图区| 久久久久中文| 国产精品magnet| 人人爽香蕉精品| 亚洲一级少妇| 国产免费av一区二区三区| 亚洲少妇自拍| 福利一区二区三区视频在线观看|