当前位置: 首页 > article >正文

Angular的理解

Angular 是一个由 Google 维护的全功能前端框架,适合构建复杂的企业级应用。它采用 TypeScript 作为首选语言,提供了一套完整的解决方案,包括数据绑定、依赖注入、路由、表单处理等。

1. Angular 的核心概念

1.1 组件化架构

Angular 应用由**组件(Components)**构成,每个组件包含:

  • HTML 模板(定义 UI)
  • CSS 样式(定义外观)
  • TypeScript 类(定义逻辑)
  • 元数据(@Component 装饰器)(配置组件)
@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent {
  title = 'My Angular App';
}

1.2 模块化(NgModule)

Angular 采用模块化设计,每个模块(NgModule)封装一组相关功能:

  • 声明组件、指令、管道
  • 导入其他模块
  • 提供服务(依赖注入)
@NgModule({
  declarations: [AppComponent], // 注册组件
  imports: [BrowserModule],     // 导入其他模块
  providers: [UserService],    // 注册服务
  bootstrap: [AppComponent]    // 启动组件
})
export class AppModule {}

2. 数据绑定与变更检测

Angular 采用双向数据绑定[(ngModel)])和单向数据流@Input() / @Output())。

2.1 数据绑定方式

语法说明
{{ expression }}插值(显示变量)
[property]="expression"属性绑定(父 → 子)
(event)="handler()"事件绑定(子 → 父)
[(ngModel)]="property"双向绑定(表单输入)

2.2 变更检测(Change Detection)

  • 默认策略Default(检查所有组件)
  • 优化策略OnPush(仅当输入变化时检查)
@Component({
  changeDetection: ChangeDetectionStrategy.OnPush
})

3. 依赖注入(DI)

Angular 的 DI 系统管理服务(Services)的创建和共享:

  • @Injectable() 标记可注入的服务
  • providers 在模块或组件级别注册服务
  • 构造函数注入(自动解析依赖)
@Injectable({ providedIn: 'root' }) // 全局单例
export class UserService {
  getUsers() { return [...] }
}

@Component({
  providers: [UserService] // 组件级实例
})
export class UserComponent {
  constructor(private userService: UserService) {}
}

4. 路由(Router)

Angular 提供 @angular/router 进行 SPA 导航:

  • RouterModule.forRoot(routes) 配置路由
  • <router-outlet> 渲染匹配的组件
  • Router 服务 编程式导航
const routes: Routes = [
  { path: '', component: HomeComponent },
  { path: 'users', component: UserListComponent }
];

@NgModule({
  imports: [RouterModule.forRoot(routes)],
})
export class AppModule {}

5. 表单处理

Angular 提供模板驱动表单响应式表单两种方式:

5.1 模板驱动表单

  • 使用 ngModel 绑定数据
  • 适合简单表单
<form #form="ngForm" (ngSubmit)="onSubmit(form)">
  <input name="username" ngModel required>
  <button type="submit">Submit</button>
</form>

5.2 响应式表单

  • 使用 FormControlFormGroup 动态管理表单
  • 适合复杂表单验证
loginForm = new FormGroup({
  username: new FormControl('', Validators.required),
  password: new FormControl('')
});

6. HTTP 通信

Angular 提供 HttpClient 进行 HTTP 请求:

@Injectable()
export class ApiService {
  constructor(private http: HttpClient) {}

  getUsers() {
    return this.http.get<User[]>('/api/users');
  }
}

7. 状态管理(NgRx)

对于大型应用,可使用 NgRx(基于 Redux 的状态管理):

  • Store(全局状态)
  • Actions(触发状态变更)
  • Reducers(纯函数更新状态)
  • Effects(处理副作用,如 API 调用)
// 定义 Action
export const loadUsers = createAction('[User] Load Users');

// 定义 Reducer
const userReducer = createReducer(
  initialState,
  on(loadUsers, (state) => ({ ...state, loading: true }))
);

8. Angular 的优势与劣势

✅ 优势

  • 全功能框架:内置路由、表单、HTTP、依赖注入等
  • TypeScript 支持:强类型,减少运行时错误
  • 企业级适用:适合大型复杂应用
  • CLI 工具ng generate 快速生成代码
  • 长期支持(LTS):Google 维护,版本稳定

❌ 劣势

  • 学习曲线陡峭:概念多(模块、依赖注入、RxJS 等)
  • 性能开销:比 React/Vue 稍重(但可通过 OnPush 优化)
  • 灵活性较低:相比 React,Angular 更“固执己见”

9. Angular vs React vs Vue

特性AngularReactVue
架构全功能框架库(需搭配生态)渐进式框架
语言TypeScriptJavaScript/TSJavaScript/TS
数据绑定双向/单向单向双向/单向
学习曲线
适用场景企业级应用灵活生态快速开发

10. 学习资源

  • 官方文档:angular.io
  • 教程
    • Angular Tour of Heroes
    • Ultimate Angular(付费)
  • 社区
    • Angular Subreddit
    • Angular Discord

总结

Angular 是一个强大但复杂的框架,适合需要长期维护的大型项目。如果你喜欢结构化、强类型、全栈式解决方案,Angular 是一个很好的选择。但对于小型项目或快速原型开发,React 或 Vue 可能更合适。


http://www.kler.cn/a/610552.html

相关文章:

  • html5炫酷3D立体文字效果实现详解
  • 大模型学习:从零到一实现一个BERT微调
  • 关于deepin上WPS读取windows上的docx文件
  • 快速创建 Java 8 兼容的 Spring Boot 项目(阿里云脚手架)
  • Qt+FFmpeg+SDL2播放进度显示及定位播放
  • 视频结构化框架VideoPipe-OpenCV::DNN-TensorRT安装教程【Nvidia各系列显卡-亲测有效】
  • 【AI学习】概念了解
  • 【NLP 43、文本生成任务】
  • 鸿蒙 分布式数据摘要
  • Rust从入门到精通之进阶篇:12.高级类型系统
  • 人体的三个 Bug
  • 前端模拟 websocket 请求小工具
  • ngx_http_compile_complex_value
  • 文献学习:单细胞+临床+模型构建 | 一篇Molecular Cancer文献如何完整解读CDK4/6i耐药机制
  • SpringBoot大学生竞赛管理系统设计与实现
  • Redis 在后端系统中的高效应用
  • 去中心化金融
  • Maven插件学习(一)——生成可执行的 JAR 文件
  • AI时代智慧园区新标杆:华为联合51WORLD打造智能运营中心2.0
  • 六十天Linux从0到项目搭建(第五天)(file、bash 和 shell 的区别、目录权限、默认权限umask、粘滞位、使用系统自带的包管理工具)