5

我刚刚加入了一个基于 Lerna 代码架构的新 VueJS / Webpack:

package.json
lerna.json
packages/
modules/
plugins/

大约应用程序的每个页面都被设置为一个单独的模块,我觉得这很奇怪,虽然我不是专家,但我不确定这是设置 Lerna 架构的正确方法。

尽管如此,package.json 定义了以下内容:

"scripts": {
"bootstrap": "npm install && npm run lerna && npm run app-build",
"lerna": "lerna bootstrap --hoist --nohoist=axios --nohoist=vue-chartist --nohoist=chardist",
"publish": "lerna publish",
"clean": "lerna clean",
"test": "lerna run test --parallel",
"start": "lerna run start --stream --scope=main-module",
"app-build": "lerna run build --stream --scope=main-module",
"doc": "good-doc"}

和应用程序,虽然中等大小,我会说:

带有 node_modules 的应用程序的大小

构建总是很慢(+30 分钟)。在每个构建中。构建是这样执行的:

cross-env BACK_URL=back_url npm run bootstrap --hoist

有没有什么好的做法可以更快地构建?关于我的项目中可能设置错误的任何想法?或者这只是正常的......

4

2 回答 2

3

我从 --hoist 转移到使用纱线工作区(https://yarnpkg.com/blog/2017/08/02/introducing-workspaces/)。

我的问题不在于性能,而在于是否有可能使用 nohoist 选项(https://yarnpkg.com/blog/2018/02/15/nohoist/)。由于一些 react-scripts 依赖性,我在一个非常简单的设置中遇到了一些错误,所以我需要从提升中排除模块。

这是我的基本配置:

--> lerna.json
{
  "version": "0.0.0",
  "packages": [
    "packages/*",
  ],
  "npmClient": "yarn",
  "useWorkspaces": true
}

---> package.json
{
  "name": "root",
  "private": true,
  "workspaces": {
    "packages": ["packages/*""],
    "nohoist": ["**/babel-jest", "**/eslint", "**/jest"]
  },
  "devDependencies": {
    "lerna": "^3.4.3"
  }
}
于 2018-10-24T11:12:41.133 回答
0

构建缓慢是由于我的计算机+我猜要一起构建的大量文件。我们已经实现了 lerna,因为应用程序的每个页面都是一个单独的包,这并不是 lerna 的真正用途。

我们从基础设施中删除了 lerna,现在我们的情况更好了。

于 2019-06-18T13:18:47.627 回答