包管理器

(1)pnpm(基于hard link + symlink)

  • 基于硬链接机制(hard link)/内容寻址晋升包的装置速度

    依赖包被存储在一个全局的store目录下,不同的我的项目依赖同一个包(版本雷同)时,会硬链接至此地位,无需重新安装, 即便一个包的不同版本,pnpm 也会极大水平地复用之前版本的代码
  • 应用软连贯(符号链接,symlink, 相似于windows快捷方式)的非扁平的node_modules构造

    仅将我的项目的间接依赖项增加到 node_modules 的根目录下, 通过符号连贯查找虚构磁盘目录.pnpm下的依赖包
node_modules/express/...     // 符号连贯node_modules/.pnpm/express@4.17.1/node_modules/xxx     // virtual store

(2)npm

  • package-lock.json锁定版本

(3)yarn

  • 并行装置
  • 缓存
  • yarn.lock锁定版本

性能比照:
pnpm > yarn > npm

命令区别:

install all:   npm install / yarn / pnpm installinstall:   npm install xx (-D) / yarn add xx (-D) / pnpm add xx (-D)uninstall:   npm uninstall xx (-D) / yarn remove xx (-D) / pnpm remove add xx (-D)update: npm update xx / yarn upgrade xx / pnpm update xx

相干文件:
.lock文件
该文件记录了package.json依赖的模块,以及依赖的依赖,每次装置都是雷同的后果,解决我的项目问题,此文件用来对整个依赖树(我的项目中援用的模块以及模块依赖的模块)进行版本固定
cnpm install无奈辨认该文件

.npmrc文件
一些罕用的配置:
proxy, https-proxy:指定npm应用代理
registry: 指定npm下载安装包的源( 默认:https://registry.npmjs.org/)

nvm: node.js版本管理工具
mrm: 镜像源管理工具

切换镜像源:(1)nrm use xxxx(2)npm install xxx -g --registry=url(3)npm config set registry  url