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

詳解如何修改 node_modules 里的文件

 更新時間:2020年05月22日 09:30:33   作者:沉末_  
這篇文章主要介紹了詳解如何修改node_modules里的文件,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

前言

有時候使用npm上的包,發(fā)現(xiàn)有bug,我們知道如何修改,但是別人可能一時半會沒法更新,或者是我們特殊需求,別人不愿意修改,這時候我們只能自己動手豐衣足食。那么我們應該如何修改別人的源碼呢?首先,直接修改node_modules里面的文件是不太行的,重新安裝依賴就沒有了。一般常用辦法有兩個:

  • 下載別人代碼到本地,放在src目錄,修改后手動引入。
  • fork別人的代碼到自己倉庫,修改后,從自己倉庫安裝這個插件。

這兩個辦法的缺陷就是:更新麻煩,我們每次都需要手動去更新代碼,無法與插件同步更新。如果我們要修改的代碼僅僅是別人的一個小模塊,其他大部分代碼都不動,這時候有一個很投機的操作:利用 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會替換我們寫的“簡寫路徑”,并且它對node_modules里面的文件也是生效的。這時候我們可以將別人源碼里面引用模塊的路徑替換成我們自己的文件。
具體操作如下:

  1. 找到別人源碼里面的需要修改的模塊,到src目錄
  2. 修改其中的bug,注意里面引用其他的文件都需要寫成絕對路徑
  3. 找到這個模塊被引入的路徑(我們需要攔截的路徑)
  4. 配置webpack alias

實際操作一下

以qiankun框架的patchers模塊為例:

文件被引用的路徑為:./patchers(我們要攔截的路徑)

文件內(nèi)容為:

復制內(nèi)容到src/assets/patchers.js,修改其 import 路徑為絕對路徑,并添加我們的代碼:

配置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'))
 }
};

運行代碼,控制臺打印成功,表明我們已經(jīng)成功覆蓋別人的代碼,而且別人的代碼有更新時,我們也可以同步更新,只是這個模塊的代碼使用我們自定義的。打包之后也是可以的。

補充:使用patch-package來修改

經(jīng)掘友 @Leemagination 指點,使用patch-package來修改node_modules里面的文件更方便

步驟也很簡單:

  1. 安裝patch-package:npm i patch-package --save-dev
  2. 修改package.json,新增命令postinstall:
"scripts": {
+ "postinstall": "patch-package"
 }

修改node_modules里面的代碼

執(zhí)行命令:npx patch-package qiankun。

第一次使用patch-package會在項目根目錄生成patches文件夾,里面有修改過的文件diff記錄。

當這個包版本更新后,執(zhí)行命令:git apply --ignore-whitespace patches/qiankun+2.0.11.patch即可。其中qiankun+2.0.11.patch是它生成的文件名。

結尾

這個辦法雖然投機,也有很多局限性,但是也很好用,技術就是需要不斷的探索。有什么問題或者錯誤,歡迎指出!

到此這篇關于詳解如何修改 node_modules 里的文件的文章就介紹到這了,更多相關node_modules 修改內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Node.js 路由的實現(xiàn)方法

    Node.js 路由的實現(xiàn)方法

    這篇文章主要介紹了Node.js 路由的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-06-06
  • node.js學習總結之調式代碼的方法

    node.js學習總結之調式代碼的方法

    調式代碼很多時候類似于查案一樣,只是結果的重要程度不同,警察查案為的是人民安穩(wěn),而我們調式則是為了系統(tǒng)的安穩(wěn)。既然這樣我們就不要冤枉任何一段代碼和程序,以免他們受到不合理的懲罰。
    2014-06-06
  • Nodejs中的JWT和Session的使用

    Nodejs中的JWT和Session的使用

    這篇文章主要介紹了Nodejs中的JWT和Session的使用,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-08-08
  • nodejs插件及用法整理

    nodejs插件及用法整理

    在本篇文章里小編給大家整理的是一篇關于nodejs插件及用法相關內(nèi)容,有興趣的朋友們可以跟著學習參考下。
    2021-11-11
  • Nodejs讀取本地json文件,輸出json數(shù)據(jù)接口方式

    Nodejs讀取本地json文件,輸出json數(shù)據(jù)接口方式

    這篇文章主要介紹了Nodejs讀取本地json文件,輸出json數(shù)據(jù)接口方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • npm使用淘寶鏡像及切換回官方源的操作命令

    npm使用淘寶鏡像及切換回官方源的操作命令

    這篇文章主要給大家介紹了npm使用淘寶鏡像及切換回官方源的操作命令,文中給大家介紹的非常詳細,對大家的學習或工作有一定的幫助,需要的朋友可以參考下
    2024-02-02
  • 在koa中簡單使用Websocket連接的方法示例

    在koa中簡單使用Websocket連接的方法示例

    本文主要介紹了在koa中簡單使用Websocket連接的方法示例,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • node實現(xiàn)簡單的反向代理服務器

    node實現(xiàn)簡單的反向代理服務器

    本篇文章主要介紹了node實現(xiàn)簡單的反向代理,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • 詳解nodejs操作mongodb數(shù)據(jù)庫封裝DB類

    詳解nodejs操作mongodb數(shù)據(jù)庫封裝DB類

    這篇文章主要介紹了詳解nodejs操作mongodb數(shù)據(jù)庫封裝DB類,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04
  • 基于node.js依賴express解析post請求四種數(shù)據(jù)格式

    基于node.js依賴express解析post請求四種數(shù)據(jù)格式

    本篇文章主要介紹了node.js依賴express解析post請求四種數(shù)據(jù)格式,主要是www-form-urlencoded,form-data,application/json,text/xml,有興趣的可以了解一下。
    2017-02-02

最新評論