【发布时间】:2018-10-30 19:36:21
【问题描述】:
nrwl/nx 的最大优势是在一个项目中实现多个工作区。
现在angular 6 也支持它。
nx 与 angular@6 相比还有哪些其他改进?
【问题讨论】:
-
Nrwl 在their wiki 发布了一个页面。
-
现在是空的 xD xD
nrwl/nx 的最大优势是在一个项目中实现多个工作区。
现在angular 6 也支持它。
nx 与 angular@6 相比还有哪些其他改进?
【问题讨论】:
nx 很棒,我使用它是因为我们在一个大项目中有 5 个 Angular 应用程序,而且我认为 nrwl/nx 是为复杂的企业应用程序而设计的,所以如果你有一个由许多前端应用程序组成的大项目,它会很有用,但即使对于一个会给你带来很多好处的应用程序,nx 也有一些好处:
使用一个命令,您可以构建或测试受您的更改影响的应用
yarn affected:build --all --prod
yarn affected:test --all --prod
现在可以生成多种类型的前端应用程序ANGULAR、REACT // 用于生成反应应用程序 ng add @nrwl/react # 将 React 功能添加到您的工作区 ng g @nrwl/react:application reactAppName
// for generating an angular app
ng add @nrwl/angular
ng g @nrwl/angular:application angularAppName
为您的前端应用(如 Nest)生成后端应用,并以灵活的方式在前端和后端应用之间创建共享库
ng add @nrwl/nest
ng g @nrwl/nest:app api --frontendProject=YOU_FRONTEND_PROJECT // link the generate nest app to a specific frontend app
【讨论】:
我在过去的两份工作中使用并提倡使用 Nx,并且(大部分)喜欢它。
我继续在普通 Angular 上使用它,因为他们不断添加新工具,这些工具支持更复杂的应用程序,并消除了与设置现代 javascript Web 应用程序相关的许多痛苦(即配置和设置地狱)将现代 Web 开发库粘合在一起时)。
他们承诺以一种支持而不是远离 Angular 的方式开发他们的产品,但可以访问对开发人员友好的工作流,这些工作流支持除 Angular CLI 开箱即用之外的其他工具。
例如,他们最近添加了对赛普拉斯 e2e 测试的支持,包括项目设置、运行测试的脚本,以及仅对受上次更改影响的项目部分运行测试的命令。
他们对请求也非常敏感,并实施了我团队成员建议的几个修复/次要功能。
总而言之,他们似乎在为已经强大的 Angular CLI 发布闪亮的新插件的速度非常快,这使它成为一个引人注目的产品。
但是,如果您的应用程序不是很复杂,您可能不需要很多这些功能。
如果您有兴趣,我已经写了几篇文章,详细介绍了我过去是如何使用它的,最近还谈到了 Cypress 的东西:
http://wtfisanapi.com/wtf-is-nrwl-nx/
http://wtfisanapi.com/htf-do-i-write-e2e-tests-with-a-stubbed-dependency-angular-nrwl-nx-edition/
【讨论】:
它的工具可以帮助您只构建您进行更改的应用程序。因此,如果您在共享库中进行更改,它可以确定哪些应用使用该库项目并仅构建它们。
【讨论】:
就我个人而言,我发现我可以调试我的库很方便,而且我在使用 NX 时不必构建它们来使用它们。这是一个非常简单的项目,它具有一些 tsconfig 的魔力,但它确实使它更容易。
此外,虽然它与 Angular CLI 6 的结构基本相同,但细微的差异对我来说更有意义。
【讨论】:
tsconfig.json 中的 paths 配置为入口文件而不是 dist 输出。