响应式网站 教程,花生壳域名注册官网,wordpress主题调度,二级网站都在一台服务器怎么做域名Npm WorkSpace 特性 1 #xff09;使用或不使用包管理工具的对比
vue-cli 这个脚手架使用 Lerna 管理#xff0c;它的项目显得非常清晰在 vue-cli 中包含很多 package 点开进去#xff0c;每一个包都有package.json它里面有很多项目#xff0c;再没有 Lerna 之前去维护和管…Npm WorkSpace 特性 1 使用或不使用包管理工具的对比
vue-cli 这个脚手架使用 Lerna 管理它的项目显得非常清晰在 vue-cli 中包含很多 package 点开进去每一个包都有package.json它里面有很多项目再没有 Lerna 之前去维护和管理这么多包是会非常困难的而 webpack 至今还没有用任何的包管理工具在其 lib 下会有非常多的模块而且它还自己写了很多脚本来进行管理各种功能同上上述正反两个例子可见不使用包管理工具整个项目维护起来会很麻烦比如说你想去给 webpack 做一些贡献很麻烦很困难因为你不太清楚你的改动对整体一个影响如果使用包管理以后它就会拆的很清楚你的改动就是聚合在一个package里面的这个就是用包管理一些好处包管理目前流行的两种方式是 workspaces 和 Lerna
2 workspaces 的基本使用
在一个脚手架项目中比如xyzcli项目中(之前一直用这个脚手架演示)创建workspaces 目录 $ mkdir workspaces cd workspaces 在 workspaces 目录中执行 $ npm init -y其实在使用 npm init 的过程中通过 $ npm init --help可以看到 Options 中存在 [-w|--workspace workspace-name [-w|--workspace workspace-name ...]]也就是 -w 的参数, 比如$ npm init -w a -w b 默认一路回车这样就会在 workspaces 目录下新建了两个包a 和 b每个包中都存在package.json其name属性分别为 a 和 b在 workspace/node_modules下 生成a和b的两个软链在 workspace/package.json 中存在 workspaces 的配置workspaces: [a,b
]好现在结构基本搭建完成现在我要在 workspaces 目录对a包进行安装依赖 $ npm i vue -w a这时候a包中安装了 chalk 的依赖但是a包中没有生成 node_modules 目录在 workspaces 目录下的 node_modules 中安装了 chalk, 而 a 的 package.json 中的 dependencies 是 chalk同时b包中的package.json中是没有的 这是 workspace 非常有意思的特性它把各个内层包的依赖抽象到了最外层来进行管理这里借助了 commonjs 中对 node_moduels 查找的特性如果当前查找不到去上一层目录中去查找由于此特性可以通过最外层来管理依赖包这样的好处是非常明显的现在在a包中使用chalk, 在package.json中添加 type: module 在 a/index.js 中编写import chalk from chalk;export default {print() {console.log(chalk.red(Hello workspace))}
}现在继续修改 a/package.json 中的 name属性修改为“somegroup/a”这时候a包就会在后续发布中自动在 somegroup 分组中了这个 somegroup 可以是自己起的任意组名好现在在workspaces目录中新增一个具有cli功能的包比如就叫做 cli 这个脚手架包$ npm init -w cli 一路回车, 创建了 cli 这个脚手架包将 cli 包的 package.json 目录中的name属性改成和a包同组如name: somegroup/cli同时在 workspaces/cli 的package.json中添加 bin 属性{bin: {cli: bin/cli.mjs}
}因为这时候 cli 脚手架包的 name 不是在一开始创建的而是一路回车之后要确定和a同组的需要执行下 $ npm i -ws 来更新下分组 这时候可以看到 workspaces/node_modules/somegroup/下存在 a 和 cli 两个软链同时可以删除 workspaces/node_modules/cli 这个软链 这时候想要在 cli 这个脚手架包中引用 a包来调试需要 在 workspaces 目录下执行 $ npm i somegroup/a -w cli这时候会在 cli 脚手架目录中添加了 somegroup/a 这个 dependencies 新建 bin/cli.mjs 编写#!/usr/bin/env nodeimport * as a from somegroup/aconst { print } a.default;
print();最后可以将 这个 cli 工具在workspaces下配置使用, 因为在 workspace/node_modules/.bin 下有这个cli的软链所以在 workspaces/package.json 中添加配置scripts: {cli: cli
},这时候在 workspaces 下执行 $ npm run cli, 这样我们的脚手架就可以直接使用了如下图 以上就是使用 workspace 来进行包的管理这里生成了3个包其中包a和包cli都在somegroup组下这里演示了脚手架包cli如何使用包a,在不发布的场景下进行调试并且对cli包本地的调试同时可以参考之前的文章https://blog.csdn.net/Tyro_java/article/details/136112045