npm 使用技巧
Published in:2023-07-03 | category: 技巧

今天总结了 npm 常用的一些命令分享给大家,希望对你有所帮助!

1. npm 基本概念

npm 全称为 Node Package Manager,是一个基于 Node.js 的包管理器,也是 Node.js 社区最流行、支持的第三方模块最多的包管理器。它的初衷就是让开发人员更容易分享和重用代码。npm 提供了命令行工具,其主要功能是管理 Node.js 包,包括安装、更新、删除、查看、搜索、发布等。

npm 最初只是 Node.js 的包管理器,但随着前端技术的不断发展,它的定位变成了广义的包管理器,可以实现 JavaScript、React、Vue、Gulp、移动开发等包管理,是目前最大、生态最为健全的包管理器。

npm 能解决 Node.js 在模块管理上的很多问题,其常见的应用场景如下:
● 从 npm 镜像服务器下载第三方模块;
● 从 npm 镜像服务器下载并安装命令行程序到本地;
● 自己发布模块到 npm 镜像服务器供他人使用。

npm 不需要单独安装,在安装 Node.js 时,就会连带着一起安装 npm 了。但是安装的 npm 不一定是最新的版本,可以使用以下命令来查看本地 npm 的版本:

1
npm -v


这里的 -v 是 –version 的缩写,表示版本。如果想升级 npm 版本,可以使用以下命令:

1
npm install npm@latest -g


这里@latest 表示最新的版本,-g 是 –global 的缩写,表示全局安装。

除此之外,还可以使用 help 命令来查看 npm 帮助:

1
npm 命令 --help


比如查看 install 的参数形式:

1
npm install --help


其中–help 可以简写为-h,上面命令的执行结果如下,可以看到 install 命令的很多形式:

常见的 npm 命令:

说完这些概念,下面就来看看 npm 在使用时有哪些实用的技巧。

2. 初始化 package

凡是使用 npm 管理的项目,都需要初始化一个 package.json 文件。

可以使用以下命令来初始化一个包:

1
npm init


当执行这个命令时,它会通过问答的形式来一步步进行设置。如果不需要修改默认的配置,直接一路回车即可。如果想跳过向导,快速生成一个 package.json 文件,可以执行以下命令:

1
npm init --yes


其中,–yes 可以简写为-y。这时生成的 package.json 文件的配置项就是 npm 的默认配置。当然这个默认配置也是可以更改的,可以通过类似下面这样的形式来修改 npm 的默认配置:

1
2
npm config set init.author.name YOUR_NAME
npm config set init.author.email YOUR_EMAIL


当执行以上命令之后,之后再执行 npm init 命令时,package.json 的作者姓名和邮箱都会初始化为我们设定的值。

3. 快速了解 package

当要使用一个包时,如果想要了解它是如何使用的,可以使用以下命令来打开这个包的主页,它会自动启动浏览器并打开这个页面,这里以 React 为例:

1
npm home react


如果想要查看这个包现存的 issue,或者公开的 roadmap,可以执行以下命令:

1
npm bugs react


如果想要查看这个包的代码地址,可以执行以下命令:

1
npm repo react


如果想要查看这个包的详细信息,可以执行以下命令:

1
npm info react


执行结果如下:

这里返回的是一个 JavaScript 对象,里面包含 react 模块的详细信息,可以通过 info 命令来获取这个对象的成员信息:

1
npm info react description


执行结果如下:


4. 安装依赖

可以使用 npm install 命令来安装需要的包,如果想把这个包自动添加到 package.json 中,可以执行以下命令,这里以安装 React 为例:

1
npm install react --save


如果想要安装不同版本的包,可以这样:

1
2
3
4
5
6
// 安装最新版本
npm install react@latest
// 安装指定版本
npm install react@16.8.0
// 安装指定区间版本
npm install react@">=16.8.0 <17.0.1"


当使用 npm 安装依赖时,分为本地安装(local)和全局安装(global),它俩的区别就是是否包含-g 参数:

| 命令

| 简写

| 说明

| |
| |

| 无

| 无

| 将模块安装到本地 node_modules 目录下,但不保存在 package.json 中。

|
| –save

| -S

| 将模块安装到本地 node_modules 目录下,同时保存到 package.json 中的 dependencies 配置项中,在生产环境下这个包的依赖依然存在。

|
| –sava-dev

| -D

| 将模块安装到本地 node_modules 目录下,同时保存到 package.json 中的 devDependencies 配置项中,仅供开发时使用。

|
| –global

| -g

| 安装的模块为全局模块,如果命令行模块,会直接链接到环境变量中。

|

可以使用 require 关键字来引入本地安装的包。为了避免引用模块消失,保证依赖模块都会出现在 package.json 中,最好在 npm install 时加上–save。

需要注意,在执行 npm install 命令时,npm 5 之前只会下载,不会保存依赖信息。如果需要保存,就需要加上 –save 选项, npm 5 以后就可以省略 –save 选项了,它会自动保存。

5. 锁定依赖

当使用–save 来安装依赖时,npm 会把这个依赖保存起来,并添加^前缀,他表示,当再次执行 npm install 命令时,会自动安装这个包在此大版本下的最新版本。如果想要修改这个功能,可以执行以下命令:

1
npm config set save-prefix='~'


执行完该命令之后,就会把^符号改为~符号。当再次安装新模块时,就从只允许小版本的升级变成了只允许补丁包的升级。

如果想要锁定当前的版本,可以执行以下命令:

1
npm config set save-exact true


这样每次 npm install xxx –save 时就会锁定依赖的版本号,相当于加了 –save-exact 参数。建议线上的应用都采用这种锁定版本号的方式。

为了彻底的锁定依赖的版本,让应用在任何机器上都安装同样的版本,可以执行以下命令:

1
npm shrinkwrap


执行这个命令之后,就会在项目的根目录产生一个 npm-shrinkwrap.json 配置文件,这里面包含了通过 node_modules 计算出的模块的依赖树及版本。只要目录下有 npm-shrinkwrap.json 则运行 npm install 时就会优先使用 npm-shrinkwrap.json 中的配置进行安装,没有则使用 package.json 进行安装。

6. 搜索依赖

npm 为我们提供了 search 命令,用于搜索 npm 仓库,它搜索的参数可以是一个字符串,也可以是一个正则表达式:

1
npm search react


搜索结果如下:

当然,我们也可以去 node.js 官网去找:https://www.npmjs.com/

想要找到一个合适的依赖包可能并不是一件容易的事。这时,可以使用网站https://npms.io/,这里将各个包的质量、受欢迎度、可维护性等指标做了量化。这些指标包括:是否使用了过时的依赖包、是否有代码检查配置、是否经过测试以及最近的版本是何时发布的等。

不过,更直接方法可能就是去搜索引擎看别人的推荐了~

7. 更新、卸载依赖

npm 为我们提供了更新依赖版本的命令:

1
npm update [package name]


如果想要更新全局安装的模块,需要添加参数 -global:

1
npm update -global [package name]


当执行这两个命令时,它会先到远程仓库查询最新版本,然后查询本地版本。如果本地版本不存在,或者远程版本较新,就会安装。

如果想要更新该依赖包在 package.json 中的版本,就需要使用-S 或者–save 参数。需要注意的是,从 npm v2.6.1 开始,npm update 只会更新顶层的模块,而不更新依赖的依赖模块,而之前的版本是递归更新的。如果想要这种效果,可以使用以下命令:

1
npm --depth 9999 update


除了可以更新包之外,还可以删除指定的包:

1
npm uninstall [package name]


如果想要删除全局的包,需要添加参数 -global:

1
npm uninstall [package name] -global

8. 查找过时的包

npm 提供了一个命令来查看过时的依赖:

1
npm outdated


在我的项目中执行该命令,输出结果如下:

可以看到,这里列出了过时依赖的包名称、当前的版本、希望的版本、最新的版本、依赖在本地路径、依赖这个包的项目名称。

可以通过以下命令来检查 npm 包的最新版本:

1
2
3
4
5
6
7
// 展示包的信息
npm view <package-name>
npm v <package-name>
// 展示最新版本
npm v <package-name> version
// 展示所有版本
npm v <package-name> versions


9. 执行脚本

npm 不仅可以用于管理模块,还可以用于执行脚本。在 package.json 文件中有一个 scripts 字段,可以用于定义脚本命令,功 npm 使用。我们除了可以在 package.json 文件中查看有哪些命令,也可以使用以下命令来查看所有脚本命令:

1
npm run


我的项目中执行该命令之后的结果如下:

可以看到,这里定义了 dev、build、build:test 等命令,如果需要执行这些命令,只要这样执行即可:

1
2
npm run dev
npm run build


这里不在多说,这或许是我们平时用的最多的命令了,可以根据实际开发情况,来定制自己的 npm 命令。

10. 安装可靠的依赖

可以使用 npm ci 命令来清理、安装依赖项。它通常用于 CI/CD 等自动化环境,使用它可以获得可靠的依赖。
当执行该命令时,它会先删除本地的 node_modules 文件,因此它不需要去校验已下载文件版本与控制版本的关系,也不用校验是否存在最新版本的库,所以下载的速度相比 npm install 会更快。之后它会按照 package-lock.json 文件来安装确切版本的依赖项。并且不会将这个版本写入 package.json 或者 package-lock.json 文件。

使用该命令时,需要注意:
● 项目必需有 package-lock.json 或 npm-shrinkwrap.json 文件,如果没有,该命令将不起作用;
● npm ci 是 npm v6 中引入了的新命令,所以使用该命令时需要确保 npm 版本要>=5.7;
● npm ci 不能用来安装单个依赖,只能用来安装整个项目的依赖;
● npm ci 会安装 dependencies 和 devDependencies;
● 整个安装过程不会更新 package.json 或 package-lock.json 文件,整个安装过程是锁死的;
● 当 package-lock.json 中的依赖和 package.json 中不一致时,npm ci 会退出但不会修改 package-lock.json 文件。

11. 删除重复的包

我们可以通过运行 npm dedupe 命令来删除重复的依赖项。该命令通过删除重复包并在多个依赖包之间共享公共依赖项来简化整体的结构。它会产生一个扁平的、去重的树。

1
2
npm dedupe
npm ddp

12. 扫描漏洞

可以运行 npm audit 命令来扫描项目,来查找所有依赖项中存在的漏洞:

1
npm audit


来看我的项目扫描结果:

可以运行以下命令来自动安装所有易受攻击包的补丁版本:

13. 列举已安装的包

可以通过以下命令来获取整个项目的包信息:

1
npm list


npm list 命令以树型结构列出当前项目安装的所有模块,以及它们依赖的模块。

如果加上 global 参数,就会列出全局安装的模块:

1
npm list -global


也可以查看指定包的依赖,比如在我现在做的项目下,执行以下命令:

1
npm list react


还可以使用 npm ls 命令来查看指定包的依赖信息:

1
npm ls react

可以使用–depth 参数来限制搜索的深度:

1
npm ls --depth=1

14. 测试本地包

当我们在本地开发 npm 模块时,可以使用 npm link 命令来将本地的 npm 模块连接到对用的项目中去,便于对模块进行调试和测试。使用方式也很简单,在项目中执行以下命令:

1
npm link

执行完该命令之后,就会为这个 npm 包创建到全局,路径是 {prefix}/lib/node_modules/,它是一个快捷方式。之后我们就可以使用以下命令来在需要这个模块的项目中链接这个包:

1
npm link 模块名

这里的模块名就是依赖包的名称,也就是模块包的 package.json 文件中的 name 字段值。

如果不想继续使用了,执行以下命令来解除 link 即可:

1
npm unlink 模块名
Prev:
VS Code 快捷方式
Next:
Google 搜索技巧