gpt4 book ai didi

angular - 核心、共享和功能模块中应该包含哪些内容?

转载 作者:行者123 更新时间:2023-12-05 00:45:20 27 4
gpt4 key购买 nike

我已经阅读了很多关于这个主题的文章,但我仍然无法处理这个问题。对不起,如果它是重复的,无论如何!

所以基本上,我正在从头开始构建一个 Angular 应用程序,并且我想按照最佳约定来组织我的代码。我有一个核心模块,目前包括一个通用数据访问单例服务和一个使用它的身份验证服务。我不明白的是,什么时候应该做一个功能模块,什么时候该功能属于核心模块。

核心模块树:

enter image description here

例如,Auth 听起来像应用程序核心,但在我的情况下,它还包含一些声明(组件等),并且可能需要从共享模块导入一些 UI 原子/分子。它是否值得一个功能模块,直接在根模块中导入?我应该让核心模块导出身份验证模块的声明吗?或者我应该将身份验证(核心模块)的提供者分开并制作另一个身份验证功能模块(用于声明)?

布局模块、模态模块等也是如此。

谢谢!

最佳答案

对于小型应用程序,您无需考虑这一点。但如果应用程序足够大,您可以将应用程序模块化。

对于具有大量路由的大型应用程序,您可以考虑延迟加载。延迟加载将有助于保持初始包大小更小,这意味着在加载应用程序时,首先只会加载核心模块。它将减少您的应用的初始加载时间。

核心模块

  • 此模块随应用一起加载。
  • 将包含单例项 - 在整个应用中仅实例化一次或仅在一个地方使用的项。
  • AppModule 只会导入一次,其他功能模块不会导入此模块。

您可以将以下项目放入核心模块中(如果您认为合适,您可以放入其他项目)。

  • 模型:用于多个功能模块的模型。
  • 组件:身份验证、配置文件、页眉、页脚、布局、主页、错误、对话框等。
  • 服务:将由多个功能模块使用的单例服务,即日志、存储、共享、模式、身份验证、文件、微调器等。

为了防止其他功能模块重新导入核心模块,可以在CoreModule中添加以下构造函数:

constructor(@Optional() @SkipSelf() parentModule: CoreModule) {
if (parentModule) {
throw new Error(
'CoreModule is already loaded. Import it in the AppModule only.');
}
}

共享模块

  • 包含被功能模块的组件重用和引用的常用指令、管道和组件
  • 由核心模块和其他功能模块导入。
  • 导入:CommonModule、RouterModule、FormsModule、ReactiveFormsModule、Material 模块和其他库模块。
  • 声明:将在不同功能模块中重复使用的组件,即 HexadecimalCellEditorComponent。
  • exports:所有进口和申报的元素。
  • 提供者:本模块不应提供任何服务。

功能模块

声明仅在本模块中使用的模型、组件、服务和其他项目。

并且对于每个功能模块,还可以创建一个路由模块。

关于angular - 核心、共享和功能模块中应该包含哪些内容?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64040341/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com