成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

如何科學修改node_modules里的文件

開發 前端
我們應該如何修改別人的源碼呢?首先,直接修改node_modules里面的文件是不太行的,重新安裝依賴就沒有了。一般常用辦法有兩個,來看一下吧。

前言

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

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

這兩個辦法的缺陷就是:更新麻煩,我們每次都需要手動去更新代碼,無法與插件同步更新。如果我們要修改的代碼僅僅是別人的一個小模塊,其他大部分代碼都不動,這時候有一個很投機的操作:利用 webpack alias 來覆蓋別人代碼。

webpack alias 的作用

webpack alias一般用來配置路徑別名,使我們可以少寫路徑代碼: 

  1. chainWebpack: config => {  
  2.     config.resolve.alias  
  3.       .set('@', resolve('src'))  
  4.       .set('#', resolve('src/views/page1'))  
  5.       .set('&', resolve('src/views/page2'));  
  6. }, 

也就是說,webpack alias會替換我們寫的“簡寫路徑”,并且它對node_modules里面的文件也是生效的。這時候我們可以將別人源碼里面引用模塊的路徑替換成我們自己的文件。

具體操作如下:

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

實際操作一下

以qiankun框架的patchers模塊為例:

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

文件內容為:

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

配置webpack alias(我用的是vue-cli4,配置文件是vue.config.js): 

  1. const path = require('path');  
  2. module.exports = {  
  3.   chainWebpack: config => {  
  4.     config.resolve.alias  
  5.       .set('./patchers', path.resolve(__dirname, 'src/assets/patchers.js'))  
  6.   } 
  7. }; 

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

補充:使用patch-package來修改

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

步驟也很簡單:

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

      3.  修改node_modules里面的代碼

      4.  執行命令:npx patch-package qiankun。

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

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

關于這個 loader 我已經發布到 npm 上,有興趣的朋友可以直接調用 npm install async-catch-loader -D 安裝和研究,使用方法和一般 loader 一樣,記得放在 babel-loader 后面,以便優先執行,將注入后的結果繼續交給 babel 轉義 

  1.  
  2.     test: /\.js$/,  
  3.     use: [  
  4.         "babel-loader?cacheDirectory=true",  
  5.         'async-catch-loader'  
  6.     ]  

更多細節和源代碼可以查看 github,同時本文對您有收獲的話,希望能點個 star,非常感謝~ 

 

責任編輯:龐桂玉 來源: 前端教程
相關推薦

2022-09-19 13:57:24

文件前端代碼

2022-06-14 09:04:55

前端npm

2025-07-02 04:55:00

2025-02-05 08:54:36

rimrafNode.js工具

2022-10-20 13:05:53

patches文件生成

2025-03-04 07:30:00

開發前端Node.js

2010-12-08 12:34:46

文件傳輸

2010-07-27 13:46:18

Flex swf

2021-05-10 11:33:11

數字化

2021-07-03 17:43:03

Node.jsNode變量

2011-05-17 10:43:18

oracleblob字段

2016-05-19 13:44:53

云計算大數據

2020-05-27 11:16:49

數據科學機器學習Python

2010-01-29 09:08:57

Windows 7系統權限

2021-01-19 08:07:50

Linux日期文件

2014-08-21 08:59:44

2015-10-12 16:20:55

隱藏文件夾Windows

2019-11-20 10:24:43

Linux重復文件磁盤

2019-11-20 10:23:51

磁盤WindowsLinux

2021-05-18 09:01:39

Node.jsJSON文件
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美激情视频一区二区三区在线播放 | 最新中文字幕第一页视频 | 欧美美女二区 | 精品日韩在线 | 一级做a爰片性色毛片16美国 | 免费看大片bbbb欧美 | 在线视频一区二区 | 欧美日韩在线观看视频网站 | 日韩精品在线看 | 国产美女精品 | 欧美黄色大片在线观看 | 欧美综合国产精品久久丁香 | 日韩欧美精品一区 | 在线视频99| 美女拍拍拍网站 | 国产伦精品一区二区三区照片91 | 伊人青青久久 | 精品国产一区二区三区性色 | 日屁视频| 日一区二区 | 中文字幕日韩欧美 | 国产精品一区二区久久久久 | 亚洲精品1 | 亚洲视频免费 | 91精品国产91久久久久久最新 | 91精品国产综合久久香蕉922 | 午夜视频在线播放 | 久久久久久国产 | 久久久久久久一区 | 精品国产免费一区二区三区演员表 | 国产精品视频久久 | 日日操操 | 欧美久久影院 | 欧美日韩一区二区三区在线观看 | 欧美1—12sexvideos | 黑人一级黄色大片 | 国产精品一区二区久久久久 | 国产乱码精品一品二品 | 欧美精品一区二区三区在线 | 成人在线国产 | 欧美一区二区成人 |