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

vue之多項目|多工程共用相同組件的思路解讀

 更新時間:2023年05月24日 10:04:42   作者:搬磚怪  
這篇文章主要介紹了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ā)布很麻煩。

npm文檔

但是這里要介紹一下發(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)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • vue實現(xiàn)計算器封裝

    vue實現(xiàn)計算器封裝

    這篇文章主要為大家詳細介紹了vue實現(xiàn)計算器的封裝,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • Vue中導入excel文件的兩種方式及使用步驟

    Vue中導入excel文件的兩種方式及使用步驟

    這篇文章主要介紹了Vue中導入excel文件的兩種方式,大概有兩種導入文件的方法:form表單和el-upload,本文結合示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-12-12
  • 手動實現(xiàn)vue2.0的雙向數(shù)據(jù)綁定原理詳解

    手動實現(xiàn)vue2.0的雙向數(shù)據(jù)綁定原理詳解

    這篇文章主要給大家介紹了關于手動實現(xiàn)vue2.0的雙向數(shù)據(jù)綁定原理的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-02-02
  • vue項目中使用particles實現(xiàn)粒子背景效果及遇到的坑(按鈕沒有點擊響應)

    vue項目中使用particles實現(xiàn)粒子背景效果及遇到的坑(按鈕沒有點擊響應)

    為了提高頁面展示效果,登錄界面內(nèi)容比較單一的,粒子效果作為背景經(jīng)常使用到,vue工程中利用vue-particles可以很簡單的實現(xiàn)頁面的粒子背景效果,本文給大家分享在實現(xiàn)過程中遇到問題,需要的朋友一起看看吧
    2020-02-02
  • vue.js樹形組件之刪除雙擊增加分支實例代碼

    vue.js樹形組件之刪除雙擊增加分支實例代碼

    本文通過實例代碼給大家講解vue.js樹形組件之刪除雙擊增加分支功能,非常不錯,具有參考借鑒價值,需要的的朋友參考下
    2017-02-02
  • Vue el-upload單圖片上傳功能實現(xiàn)

    Vue el-upload單圖片上傳功能實現(xiàn)

    這篇文章主要介紹了Vue el-upload單圖片上傳功能實現(xiàn),本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-11-11
  • 在vue項目中如何獲取視頻的時長

    在vue項目中如何獲取視頻的時長

    這篇文章主要介紹了在vue項目中如何獲取視頻的時長,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vant自定義引入iconfont圖標及字體的方法步驟

    vant自定義引入iconfont圖標及字體的方法步驟

    因為vantUI給的圖標非常少,為了滿足自己的需求,就應該找到一種方法來向vant添加自己自定義的圖標,對于自定義圖標我第一時間想到的就是阿里的iconfont矢量圖庫,這篇文章主要給大家介紹了關于vant自定義引入iconfont圖標及字體的方法步驟,需要的朋友可以參考下
    2023-09-09
  • element-ui el-select下拉框el-date-picker彈出框定位問題解決方案(推薦)

    element-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
  • vue實現(xiàn)移動端input上傳視頻、音頻

    vue實現(xiàn)移動端input上傳視頻、音頻

    這篇文章主要為大家詳細介紹了vue實現(xiàn)移動端input上傳視頻、音頻,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-08-08

最新評論