在一个项目中,我们会用 HRM 热更新来让我们修改的代码在浏览器中快速看到效果,快速验证我们的代码是否正确。

当项目开始变大,为了提效、跨项目复用,我们会不可避免的需要开始去拆分一些通用的 NPM 模块。

对于 NPM 包的调试方式,传统的方法是下面这样子的:

# 一、直接修改 dependencies

{
  "dependencies": {
    "npm-test": "file:实际包地址"
  }
}

真正的纯手工 😂,上线后还需要时刻记得修改 dependencies,现在应该也没什么人用这种方法了,不细讲了。

官方文档[1]

原理:将调试的包跟项目中做一个软链

cd 对应npm包地址
npm link

之后可以在命令行中看到如下日志,则说明 npm 库已经链接到你本地 node_modules 下面了

✔ Installed 17 packages
✔ Linked 1 latest versions
✔ Run 0 scripts
✔ All packages installed (used 213ms(network 209ms), speed 4.25KB/s, json 1(910B), tarball 0B)
link /Users/beidan/.nvm/versions/node/v14.5.0/lib/node_modules/npm-test@ -> /对应的包实际地址

之后只需要将项目对应的包链到你本地的全局地址即可

cd 项目地址
npm link npm-test

同样的,我们可以在命令行中看到如下日志,则说明项目中的包也已经链接成功

link /对应的包实际地址@ -> /Users/beidan/.nvm/versions/node/v14.5.0/lib/node_modules/npm-test

对于 Npm link 方式,「因为 Npm 和 项目属于不同的项目,它们有自己的 node_modules」,如果组件和应用都使用了同一个依赖,它们会在各自的 node_modules 去查找,如果这个依赖不支持多例,应用就会异常。如果 npm 的编译规则 和应用的编译规则不匹配,也同样会出问题。如下:

hooks can only be called inside the body of a function component

提示

NPM 组件 和你的项目使用了 React Hooks 的情况,React 会报致命异常。(原因是 React Hooks 依赖上下文,所以全局只能使用一个,即使是版本完全一样的,官方推荐的解决方法 React 错误提示[2]

# 三、更好的调试方式:yalc

官方文档[3]

yalc 将组件的包依赖提升至应用中,在全局添加组件依赖,在应用下新建文件拉取依赖,即使有共同的依赖也会从应用的 node_modules 去查找。「使用 yalc 可以避免上面 npm link 的依赖问题」

章节配图

使用起来也非常方便:

npm i yalc -g
yalc publish // 在对应的 npm 包中发布
yalc link // 在对应的项目中 link 对应的包

# 四、实际应用

我们期望的工作流程是这样子的。

章节配图

在灰色区域,期望是自动化的,而不是写一下代码,重新 build 一下, 那自动监听更新文件可以用一下 nodemon 。

nodemon 可以来监视文件更改并执行对应的命令。

nodemon
 --ignore dist/ # 忽略目录
 --ignore node_modules/
 --watch projects # 观察目录
 -C # 只在变更后执行,首次启动不执行命令
 -e ts,html,less,scss # 监控指定后缀名的文件
 --debug # 调试
 -x "npm run build && yalc push" # 自定义命令

提示

可以通过 nodemon -h 查看更多命令

结合 yalc ,我们来重新改造下 npm 包调试的流程。

# 一、在 npm 包中增加命令

npm 命令我写过一篇文章,不了解可以看一下: 你要知道的 Npm Script 都在这里

"scripts": {
  "build": "打包包的命令",
  "async": "npm run build && yalc push",
  "watch": "nodemon --ignore dist/ --ignore node_modules/ --watch src/ -C -e ts,tsx,scss --debug -x 'tnpm run async'", // 自动监听
},

# 二、项目中

yalc link 包名
npm run start

这样子,在 npm 包中修改,在项目中可以快速看到结果,快速验证了,并且不会出现 npm link 中各种奇奇怪怪的问题。

# Reference

居然有比 npm link 更好的调试? (opens new window)


  1. 官方文档 (opens new window)

  2. React 错误提示 (opens new window)

  3. 官方文档 (opens new window)