[Angular] 笔记 7:模块
2023-12-22 22:12:09
Angular 中的模块(modules) 是代码在逻辑上的最大划分,它类似于C++, C# 中的名字空间:
module 可分为如下几种不同的类型:
使用模块的第一个原因是要对代码进行逻辑上的划分,第二个非常重要的原因是为了实现懒惰加载(lazy loading),即不同的模块仅在使用时才加载。
生成模块相关指令举例:
VS Terminal 运行命令:
PS D:\Angular\my-app> ng generate module pokemon-base
CREATE src/app/pokemon-base/pokemon-base.module.ts (197 bytes)
这里模块名称pokemon-base
后面没有再加一个 -module
是因为Angular会自动加上一个 .module
, pokemon-base-module.module
看起来会很奇怪,从 VS code 可看到新生成的文件夹 pokemon-base
以及新文件 pokemon-base.module.ts
:
非常重要的一点,pokemon-base.module.ts
文件中要加上exports: [ ],
:
import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
@NgModule({
declarations: [],
imports: [CommonModule],
// important
exports: [],
})
export class PokemonBaseModule {}
VS Terminal 运行命令生成一个 UI 组件 pokemon-list
:
PS D:\Angular\my-app> ng generate component pokemon-base/pokemon-list --module=pokemon-base/pokemon-base.module.ts
CREATE src/app/pokemon-base/pokemon-list/pokemon-list.component.html (27 bytes)
CREATE src/app/pokemon-base/pokemon-list/pokemon-list.component.spec.ts (635 bytes)
CREATE src/app/pokemon-base/pokemon-list/pokemon-list.component.ts (298 bytes)
CREATE src/app/pokemon-base/pokemon-list/pokemon-list.component.css (0 bytes)
UPDATE src/app/pokemon-base/pokemon-base.module.ts (308 bytes)
可以看到项目中新生成的组件文件夹以及文件:
同时修改 pokemon-base.module.ts
中的 exports: [ ],
:
@NgModule({
declarations: [],
imports: [CommonModule],
// 增加 PokemonListComponent
exports: [PokemonListComponent],
})
export class PokemonBaseModule {}
修改 app.module.ts
中的 imports
:
@NgModule({
declarations: [AppComponent],
// 增加 PokemonBaseModule
imports: [BrowserModule, AppRoutingModule, PokemonBaseModule],
providers: [],
bootstrap: [AppComponent],
})
export class AppModule {}
在 app.component.html
中增加新生成的组件:
运行 ng serve
:
文章来源:https://blog.csdn.net/ftell/article/details/135159564
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!