亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue之多項(xiàng)目|多工程共用相同組件的思路解讀

 更新時(shí)間:2023年05月24日 10:04:42   作者:搬磚怪  
這篇文章主要介紹了vue之多項(xiàng)目|多工程共用相同組件的思路,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

項(xiàng)目場景

簡單介紹一下目前的項(xiàng)目場景,目前我們有三個(gè)vue工程,就是三個(gè)vue項(xiàng)目,但是每個(gè)項(xiàng)目都有自己的基礎(chǔ)組件庫,但是這些自己封裝的組件庫都一樣,都是CV過去的,但是現(xiàn)在產(chǎn)品不穩(wěn)定,這些基礎(chǔ)的組件庫可能會總改,那么問題就來了,我每次難道都要改三遍嗎?

那也太費(fèi)勁了,所以研究了一下如何在多個(gè)vue項(xiàng)目共用一套基礎(chǔ)建設(shè)的組件,這樣我就改一次就行了,不需要改很多次了。

npm簡介 

npm全稱是node package management,接觸過node知道,它是node的包管理工具,我們平時(shí)使用的npm install <安裝的包名>,都是那些作者把自己的項(xiàng)目發(fā)布到Npm上,你才能夠install安裝它,我們這個(gè)場景也可以,我把公共的組件抽出來弄成一個(gè)工程,完了發(fā)布到npm上,以后用的時(shí)候直接npm install就可以了。但是我放棄了這個(gè)選擇,因?yàn)槊看胃膭佣嫉酶陌姹局匦掳l(fā)布很麻煩。

npm文檔

但是這里要介紹一下發(fā)布npm包需要配什么東西,后面會需要這里的配置。

  "name": "pub-fe"
  "version": "0.1.1" //項(xiàng)目版本
  "description": "包描述" //這個(gè)包的描述
  "main": "src/main.js", //入口文件,默認(rèn)就是main.js
  "author": "wxs", //作者名字
  "repository": {  //npm去哪里拉去你的項(xiàng)目代碼(這個(gè)后面沒用上,)
     "type": "git",
     "url": "git+https://github.com/wangxueshun/pub-fe.git"
   }
``

具體配置

入口文件main.js

//main.js文件
import pubImp from "./packages/pubImp/index.js"
//先把公共組件放在這個(gè)數(shù)組里,這里舉列子就寫了一個(gè),有多少個(gè)就在數(shù)組里放多少個(gè)
const components = [
  pubImp
];
//這里install方法主要是為了以后用vue.use()全局注冊組件,因?yàn)槭腔A(chǔ)組件以后肯定常用,這樣就不用每個(gè)頁面都import了,這里不明白的建議百度。
const install = function (Vue) {//這個(gè)Vue參數(shù),在Vue調(diào)用install方法的時(shí)候會把Vue傳進(jìn)去
  //這里循環(huán)調(diào)用
  components.forEach(component => {
    component.install(Vue);
  });
};
export default {
  install
}

pubImp文件

我的公共組件工程的結(jié)構(gòu)

pubImp下的index.js文件

import myButton from './src/main.vue'
export default {
    install(Vue) {
        Vue.component("myButton", myButton)
    }
}

現(xiàn)在共用的包已經(jīng)寫好了,那么怎么樣才能在別的工程那樣直接引入到項(xiàng)目中呢?

npm link

在本地開發(fā)npm模塊的時(shí)候,我們可以使用npm link命令,將npm 模塊鏈接到對應(yīng)的運(yùn)行項(xiàng)目中去,方便地對模塊進(jìn)行調(diào)試和測試

1.先到我們的公共包pub-fe中執(zhí)行npm link

這時(shí)候我們的pub-fe這個(gè)文件會被連接到全局。

2.在需要pub-fe的地方引入它,執(zhí)行npm link pub-fe,我的項(xiàng)目是spp-fe所以我以這個(gè)為例子

這個(gè)時(shí)候pub-fe就會映射到spp-fe中的node_modules中,以快捷鍵的方式。

3.這個(gè)時(shí)候我們就可以跟引入別的第三方模塊一樣,引入我們的pub-fe.

使用npm link的又一點(diǎn)好處就是,你依賴的包有更新的時(shí)候,可以及時(shí)響應(yīng),不像在npm上發(fā)布的包,每次想下載最新的包都得npm install一下。

探究

那么我這么引入會不會對打包有影響呢?讓我們來探究一下。

一、執(zhí)行npm run serve

我們看一下研發(fā)環(huán)境的打包方式會造成什么影響,我就直接上引入Pub-fe之后的打包圖片了。

可以看到打出來的包pub-fe里引入進(jìn)來了,它里面也會有一些node_modules和它的一些依賴文件,對包的體積影響還是有的,但是這個(gè)研發(fā)環(huán)境的打包,webpack對研發(fā)環(huán)境的打包方式跟生產(chǎn)環(huán)境的打包方式是不一樣的,所以這個(gè)體積大就大了,我所謂就自己用。

二、執(zhí)行npm run build 生產(chǎn)環(huán)境的打包方式

讓我們看看引入Pub-fe之后對打包的影響。

可以看到這次的pub-fe中依賴的node_modules跟我們的項(xiàng)目都服用上了,不像在研發(fā)環(huán)境中他倆是兩套node_modules,所以這個(gè)對生產(chǎn)環(huán)境的打包影響近乎為零。

拓展

你可以通過這種方式進(jìn)行多個(gè)工程共用同一個(gè)依賴,是最簡單的方式,但這只適合小的團(tuán)隊(duì)使用。

你還可以用npm install +路徑的方式 ,把需要依賴的項(xiàng)目裝到node_modules里,但感覺這種沒npm link好用,每次更新公共依賴的代碼,都需要install一下。

你還可以把公共依賴發(fā)到npm上,這個(gè)是最正規(guī)的,但是我覺得太麻煩,如果團(tuán)隊(duì)大的話這么做我覺得挺合適的。

你還可以用npm install +git網(wǎng)址的方式,npm install 支持http,https.等等的方式,這里建議去看一下我最上面提到的Npm官網(wǎng)。

總結(jié)

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue實(shí)現(xiàn)計(jì)算器封裝

    vue實(shí)現(xiàn)計(jì)算器封裝

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

    Vue中導(dǎo)入excel文件的兩種方式及使用步驟

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

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

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

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

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

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

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

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

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

    在vue項(xiàng)目中如何獲取視頻的時(shí)長

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

    vant自定義引入iconfont圖標(biāo)及字體的方法步驟

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

    element-ui el-select下拉框el-date-picker彈出框定位問題解決方案(推薦)

    項(xiàng)目開發(fā)過程中發(fā)現(xiàn)el-select和el-date-picker彈出框顯示時(shí)候,滾動屏幕,導(dǎo)致彈出框定位出現(xiàn)問題,這篇文章主要介紹了element-ui el-select下拉框el-date-picker彈出框定位問題解決方案(推薦),需要的朋友可以參考下
    2024-07-07
  • vue實(shí)現(xiàn)移動端input上傳視頻、音頻

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

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

最新評論