如何优雅地在不影响项目的前提下修改node_modules中的依赖库?

2026-04-03 07:371阅读0评论SEO资讯
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计992个文字,预计阅读时间需要4分钟。

如何优雅地在不影响项目的前提下修改node_modules中的依赖库?

在Node项目中,优雅地修改`node_modules`中的依赖库的方法如下:

1. 使用npm link: - 首先,安装依赖库到本地,并使用`npm link`将其链接到全局。 - 然后,在项目中通过`npm link `将其链接到本地项目。

2. 直接修改`node_modules`: - 进入`node_modules`目录,找到需要修改的依赖库。 - 修改完成后,确保`package.json`中的版本号与修改后的版本一致。

3. 使用npm ci: - 使用`npm ci`安装依赖,它会创建一个与`package-lock.json`或`package.json`中版本一致的`node_modules`目录。

4. 使用npm shrinkwrap: - 使用`npm shrinkwrap`锁定依赖库的版本,确保项目在不同环境中的依赖一致性。

5. 使用npm update: - 使用`npm update `来更新特定的依赖库。

6. 使用npm unpublish: - 如果你有权限,可以使用`npm unpublish @`来移除一个特定的版本。

最近,我使用了一个公司内部的开源项目,由于业务需求,我需要修改其中一个依赖库。以下是具体步骤:

1. 将依赖库克隆到本地。

2.修改代码以满足业务需求。

3.使用`npm publish`发布新的版本。

4.在项目中通过`npm install @`安装新版本。

希望这些信息能对你有所帮助!

node项目中如何优雅的修改node_modules的依赖库?下面本篇文章就来带大家优雅修改node_modules中依赖库的方法,希望对大家有所帮助!

最近使用了公司内的一个开源项目,由于业务需要(不适合提MR的业务修改),需要简单的修改 @tencent/wuji-server-lite的源码,package.json如下:

"dependencies": { "@tencent/taf-config": "^2.0.4", "@tencent/wuji-server-lite": "2.0.30", "patch-package": "^6.2.0" }

一般我们有两种做法:

  • 方法一:把修改后的代码换个名字重新打个包提交到tnpm,然后直接引用这个新包

    如何优雅地在不影响项目的前提下修改node_modules中的依赖库?

  • 方法二:把代码copy移出node_modules作为本地依赖

无论是上面哪种办法,作为有代码洁癖的人来说,都觉得很别扭,我就改了某一个文件了一两行代码,却要如此臃肿的copy整个项目,更要命的是最后可能都忘了自己修改了哪里,没有diff可供追溯。

我当时就咨询了几个nodejs-er,在我没使用nodejs的这一两年时间内,nodejs是不是已经提供了什么高大上的方法解决了这个问题,比如可以指定node_modules中的某个文件被本地的另外一个替换?得到的答案是 no。

顿时我就萌生出了要自己弄一个解决这类问题的npm包,然后又按常例的事先google了一番,结果却发现已经存在了这么一个东东,叫patch-package(www.npmjs.com/package/patch-package),一看发布时间是两年前,如果我没中途去做吃鸡手游,也许这个库最先可能是被我弄出来的,哈哈。

既然不需要我再造一个轮子了,那接下来我就分享下怎么使用吧。

1、本地安装,npm i patch-package

2、在package.json 的scripts中加入 { "postinstall": "patch-package" },这是npm的一个钩子,会在依赖包被install之后执行

3、修改node_modules中的代码

4、生成patches,npx patch-package your-package-name

5、提交patches后,重新install包你就会发现是你修改后的结果

最后,这个库的官网还有一段很详细的对比,描述了什么时候用patch什么时候fork,描述的非常到位:

更多node相关知识,请访问:nodejs 教程!

以上就是node_modules中如何优雅的修改依赖库?方法介绍的详细内容,更多请关注自由互联其它相关文章!

本文共计992个文字,预计阅读时间需要4分钟。

如何优雅地在不影响项目的前提下修改node_modules中的依赖库?

在Node项目中,优雅地修改`node_modules`中的依赖库的方法如下:

1. 使用npm link: - 首先,安装依赖库到本地,并使用`npm link`将其链接到全局。 - 然后,在项目中通过`npm link `将其链接到本地项目。

2. 直接修改`node_modules`: - 进入`node_modules`目录,找到需要修改的依赖库。 - 修改完成后,确保`package.json`中的版本号与修改后的版本一致。

3. 使用npm ci: - 使用`npm ci`安装依赖,它会创建一个与`package-lock.json`或`package.json`中版本一致的`node_modules`目录。

4. 使用npm shrinkwrap: - 使用`npm shrinkwrap`锁定依赖库的版本,确保项目在不同环境中的依赖一致性。

5. 使用npm update: - 使用`npm update `来更新特定的依赖库。

6. 使用npm unpublish: - 如果你有权限,可以使用`npm unpublish @`来移除一个特定的版本。

最近,我使用了一个公司内部的开源项目,由于业务需求,我需要修改其中一个依赖库。以下是具体步骤:

1. 将依赖库克隆到本地。

2.修改代码以满足业务需求。

3.使用`npm publish`发布新的版本。

4.在项目中通过`npm install @`安装新版本。

希望这些信息能对你有所帮助!

node项目中如何优雅的修改node_modules的依赖库?下面本篇文章就来带大家优雅修改node_modules中依赖库的方法,希望对大家有所帮助!

最近使用了公司内的一个开源项目,由于业务需要(不适合提MR的业务修改),需要简单的修改 @tencent/wuji-server-lite的源码,package.json如下:

"dependencies": { "@tencent/taf-config": "^2.0.4", "@tencent/wuji-server-lite": "2.0.30", "patch-package": "^6.2.0" }

一般我们有两种做法:

  • 方法一:把修改后的代码换个名字重新打个包提交到tnpm,然后直接引用这个新包

    如何优雅地在不影响项目的前提下修改node_modules中的依赖库?

  • 方法二:把代码copy移出node_modules作为本地依赖

无论是上面哪种办法,作为有代码洁癖的人来说,都觉得很别扭,我就改了某一个文件了一两行代码,却要如此臃肿的copy整个项目,更要命的是最后可能都忘了自己修改了哪里,没有diff可供追溯。

我当时就咨询了几个nodejs-er,在我没使用nodejs的这一两年时间内,nodejs是不是已经提供了什么高大上的方法解决了这个问题,比如可以指定node_modules中的某个文件被本地的另外一个替换?得到的答案是 no。

顿时我就萌生出了要自己弄一个解决这类问题的npm包,然后又按常例的事先google了一番,结果却发现已经存在了这么一个东东,叫patch-package(www.npmjs.com/package/patch-package),一看发布时间是两年前,如果我没中途去做吃鸡手游,也许这个库最先可能是被我弄出来的,哈哈。

既然不需要我再造一个轮子了,那接下来我就分享下怎么使用吧。

1、本地安装,npm i patch-package

2、在package.json 的scripts中加入 { "postinstall": "patch-package" },这是npm的一个钩子,会在依赖包被install之后执行

3、修改node_modules中的代码

4、生成patches,npx patch-package your-package-name

5、提交patches后,重新install包你就会发现是你修改后的结果

最后,这个库的官网还有一段很详细的对比,描述了什么时候用patch什么时候fork,描述的非常到位:

更多node相关知识,请访问:nodejs 教程!

以上就是node_modules中如何优雅的修改依赖库?方法介绍的详细内容,更多请关注自由互联其它相关文章!