vue之多項目|多工程共用相同組件的思路解讀
項目場景
簡單介紹一下目前的項目場景,目前我們有三個vue工程,就是三個vue項目,但是每個項目都有自己的基礎組件庫,但是這些自己封裝的組件庫都一樣,都是CV過去的,但是現(xiàn)在產(chǎn)品不穩(wěn)定,這些基礎的組件庫可能會總改,那么問題就來了,我每次難道都要改三遍嗎?
那也太費勁了,所以研究了一下如何在多個vue項目共用一套基礎建設的組件,這樣我就改一次就行了,不需要改很多次了。
npm簡介
npm全稱是node package management,接觸過node知道,它是node的包管理工具,我們平時使用的npm install <安裝的包名>,都是那些作者把自己的項目發(fā)布到Npm上,你才能夠install安裝它,我們這個場景也可以,我把公共的組件抽出來弄成一個工程,完了發(fā)布到npm上,以后用的時候直接npm install就可以了。但是我放棄了這個選擇,因為每次改動都得改版本重新發(fā)布很麻煩。
但是這里要介紹一下發(fā)布npm包需要配什么東西,后面會需要這里的配置。
"name": "pub-fe" "version": "0.1.1" //項目版本 "description": "包描述" //這個包的描述 "main": "src/main.js", //入口文件,默認就是main.js "author": "wxs", //作者名字 "repository": { //npm去哪里拉去你的項目代碼(這個后面沒用上,) "type": "git", "url": "git+https://github.com/wangxueshun/pub-fe.git" } ``
具體配置
入口文件main.js
//main.js文件 import pubImp from "./packages/pubImp/index.js" //先把公共組件放在這個數(shù)組里,這里舉列子就寫了一個,有多少個就在數(shù)組里放多少個 const components = [ pubImp ]; //這里install方法主要是為了以后用vue.use()全局注冊組件,因為是基礎組件以后肯定常用,這樣就不用每個頁面都import了,這里不明白的建議百度。 const install = function (Vue) {//這個Vue參數(shù),在Vue調(diào)用install方法的時候會把Vue傳進去 //這里循環(huán)調(diào)用 components.forEach(component => { component.install(Vue); }); }; export default { install }
pubImp文件
我的公共組件工程的結構
pubImp下的index.js文件
import myButton from './src/main.vue' export default { install(Vue) { Vue.component("myButton", myButton) } }
現(xiàn)在共用的包已經(jīng)寫好了,那么怎么樣才能在別的工程那樣直接引入到項目中呢?
npm link
在本地開發(fā)npm模塊的時候,我們可以使用npm link命令,將npm 模塊鏈接到對應的運行項目中去,方便地對模塊進行調(diào)試和測試
1.先到我們的公共包pub-fe中執(zhí)行npm link
這時候我們的pub-fe這個文件會被連接到全局。
2.在需要pub-fe的地方引入它,執(zhí)行npm link pub-fe,我的項目是spp-fe所以我以這個為例子
這個時候pub-fe就會映射到spp-fe中的node_modules中,以快捷鍵的方式。
3.這個時候我們就可以跟引入別的第三方模塊一樣,引入我們的pub-fe.
使用npm link的又一點好處就是,你依賴的包有更新的時候,可以及時響應,不像在npm上發(fā)布的包,每次想下載最新的包都得npm install一下。
探究
那么我這么引入會不會對打包有影響呢?讓我們來探究一下。
一、執(zhí)行npm run serve
我們看一下研發(fā)環(huán)境的打包方式會造成什么影響,我就直接上引入Pub-fe之后的打包圖片了。
可以看到打出來的包pub-fe里引入進來了,它里面也會有一些node_modules和它的一些依賴文件,對包的體積影響還是有的,但是這個研發(fā)環(huán)境的打包,webpack對研發(fā)環(huán)境的打包方式跟生產(chǎn)環(huán)境的打包方式是不一樣的,所以這個體積大就大了,我所謂就自己用。
二、執(zhí)行npm run build 生產(chǎn)環(huán)境的打包方式
讓我們看看引入Pub-fe之后對打包的影響。
可以看到這次的pub-fe中依賴的node_modules跟我們的項目都服用上了,不像在研發(fā)環(huán)境中他倆是兩套node_modules,所以這個對生產(chǎn)環(huán)境的打包影響近乎為零。
拓展
你可以通過這種方式進行多個工程共用同一個依賴,是最簡單的方式,但這只適合小的團隊使用。
你還可以用npm install +路徑的方式 ,把需要依賴的項目裝到node_modules里,但感覺這種沒npm link好用,每次更新公共依賴的代碼,都需要install一下。
你還可以把公共依賴發(fā)到npm上,這個是最正規(guī)的,但是我覺得太麻煩,如果團隊大的話這么做我覺得挺合適的。
你還可以用npm install +git網(wǎng)址的方式,npm install 支持http,https.等等的方式,這里建議去看一下我最上面提到的Npm官網(wǎng)。
總結
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
手動實現(xiàn)vue2.0的雙向數(shù)據(jù)綁定原理詳解
這篇文章主要給大家介紹了關于手動實現(xiàn)vue2.0的雙向數(shù)據(jù)綁定原理的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-02-02vue項目中使用particles實現(xiàn)粒子背景效果及遇到的坑(按鈕沒有點擊響應)
為了提高頁面展示效果,登錄界面內(nèi)容比較單一的,粒子效果作為背景經(jīng)常使用到,vue工程中利用vue-particles可以很簡單的實現(xiàn)頁面的粒子背景效果,本文給大家分享在實現(xiàn)過程中遇到問題,需要的朋友一起看看吧2020-02-02element-ui el-select下拉框el-date-picker彈出框定位問題解決方案(推薦)
項目開發(fā)過程中發(fā)現(xiàn)el-select和el-date-picker彈出框顯示時候,滾動屏幕,導致彈出框定位出現(xiàn)問題,這篇文章主要介紹了element-ui el-select下拉框el-date-picker彈出框定位問題解決方案(推薦),需要的朋友可以參考下2024-07-07