詳解如何修改 node_modules 里的文件
前言
有時(shí)候使用npm上的包,發(fā)現(xiàn)有bug,我們知道如何修改,但是別人可能一時(shí)半會(huì)沒法更新,或者是我們特殊需求,別人不愿意修改,這時(shí)候我們只能自己動(dòng)手豐衣足食。那么我們應(yīng)該如何修改別人的源碼呢?首先,直接修改node_modules里面的文件是不太行的,重新安裝依賴就沒有了。一般常用辦法有兩個(gè):
- 下載別人代碼到本地,放在src目錄,修改后手動(dòng)引入。
- fork別人的代碼到自己倉庫,修改后,從自己倉庫安裝這個(gè)插件。
這兩個(gè)辦法的缺陷就是:更新麻煩,我們每次都需要手動(dòng)去更新代碼,無法與插件同步更新。如果我們要修改的代碼僅僅是別人的一個(gè)小模塊,其他大部分代碼都不動(dòng),這時(shí)候有一個(gè)很投機(jī)的操作:利用 webpack alias 來覆蓋別人代碼。
webpack alias 的作用
webpack alias一般用來配置路徑別名,使我們可以少寫路徑代碼:
chainWebpack: config => { config.resolve.alias .set('@', resolve('src')) .set('#', resolve('src/views/page1')) .set('&', resolve('src/views/page2')); },
也就是說,webpack alias會(huì)替換我們寫的“簡寫路徑”,并且它對(duì)node_modules里面的文件也是生效的。這時(shí)候我們可以將別人源碼里面引用模塊的路徑替換成我們自己的文件。
具體操作如下:
- 找到別人源碼里面的需要修改的模塊,到src目錄
- 修改其中的bug,注意里面引用其他的文件都需要寫成絕對(duì)路徑
- 找到這個(gè)模塊被引入的路徑(我們需要攔截的路徑)
- 配置webpack alias
實(shí)際操作一下
以qiankun框架的patchers模塊為例:
文件被引用的路徑為:./patchers(我們要攔截的路徑)
文件內(nèi)容為:
復(fù)制內(nèi)容到src/assets/patchers.js,修改其 import 路徑為絕對(duì)路徑,并添加我們的代碼:
配置webpack alias(我用的是vue-cli4,配置文件是vue.config.js):
const path = require('path'); module.exports = { chainWebpack: config => { config.resolve.alias .set('./patchers', path.resolve(__dirname, 'src/assets/patchers.js')) } };
運(yùn)行代碼,控制臺(tái)打印成功,表明我們已經(jīng)成功覆蓋別人的代碼,而且別人的代碼有更新時(shí),我們也可以同步更新,只是這個(gè)模塊的代碼使用我們自定義的。打包之后也是可以的。
補(bǔ)充:使用patch-package來修改
經(jīng)掘友 @Leemagination 指點(diǎn),使用patch-package來修改node_modules里面的文件更方便
步驟也很簡單:
- 安裝patch-package:npm i patch-package --save-dev
- 修改package.json,新增命令postinstall:
"scripts": { + "postinstall": "patch-package" }
修改node_modules里面的代碼
執(zhí)行命令:npx patch-package qiankun。
第一次使用patch-package會(huì)在項(xiàng)目根目錄生成patches文件夾,里面有修改過的文件diff記錄。
當(dāng)這個(gè)包版本更新后,執(zhí)行命令:git apply --ignore-whitespace patches/qiankun+2.0.11.patch即可。其中qiankun+2.0.11.patch是它生成的文件名。
結(jié)尾
這個(gè)辦法雖然投機(jī),也有很多局限性,但是也很好用,技術(shù)就是需要不斷的探索。有什么問題或者錯(cuò)誤,歡迎指出!
到此這篇關(guān)于詳解如何修改 node_modules 里的文件的文章就介紹到這了,更多相關(guān)node_modules 修改內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
node.js學(xué)習(xí)總結(jié)之調(diào)式代碼的方法
調(diào)式代碼很多時(shí)候類似于查案一樣,只是結(jié)果的重要程度不同,警察查案為的是人民安穩(wěn),而我們調(diào)式則是為了系統(tǒng)的安穩(wěn)。既然這樣我們就不要冤枉任何一段代碼和程序,以免他們受到不合理的懲罰。2014-06-06Nodejs讀取本地json文件,輸出json數(shù)據(jù)接口方式
這篇文章主要介紹了Nodejs讀取本地json文件,輸出json數(shù)據(jù)接口方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10node實(shí)現(xiàn)簡單的反向代理服務(wù)器
本篇文章主要介紹了node實(shí)現(xiàn)簡單的反向代理,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07詳解nodejs操作mongodb數(shù)據(jù)庫封裝DB類
這篇文章主要介紹了詳解nodejs操作mongodb數(shù)據(jù)庫封裝DB類,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-04-04基于node.js依賴express解析post請(qǐng)求四種數(shù)據(jù)格式
本篇文章主要介紹了node.js依賴express解析post請(qǐng)求四種數(shù)據(jù)格式,主要是www-form-urlencoded,form-data,application/json,text/xml,有興趣的可以了解一下。2017-02-02