Angular 框架入门教程:从安装到路由、服务与状态管理详解

一、引言

在前端开发领域,Angular 是一个强大且流行的框架。它由 Google 维护,基于 TypeScript,采用模块化设计,提供了组件化开发、依赖注入、路由、表单处理等丰富功能,旨在帮助开发者构建高效、可维护的单页应用程序(SPA),提升开发效率和用户体验。

二、安装 Angular

  1. 安装 Node.js 和 npm:Angular 依赖 Node.js 和 npm 运行。从 Node.js 官方网站下载并安装它们。
  2. 安装 Angular CLI:使用命令npm install -g @angular/cli安装 Angular CLI,安装完成后可用ng --version检查版本。

三、创建 Angular 项目

  1. 使用 Angular CLI 创建项目:ng new my-app,Angular CLI 会自动创建项目结构并安装依赖项。
  2. 运行项目:进入项目目录,执行cd my-app后再运行ng serve,开发服务器启动后可在浏览器中通过http://localhost:4200访问应用程序。

四、Angular 项目结构

1.项目目录结构

  1. e2e/:端到端测试目录。
  2. node_modules/:项目依赖的第三方模块。
  3. src/:项目源代码目录。
  4. .angular-cli.json:Angular CLI 的配置文件。
  5. package.json:项目的包管理文件。
  6. tsconfig.json:TypeScript 的配置文件。

2.主要文件介绍

  1. app.module.ts:定义应用程序的模块。
  2. app.component.ts:定义应用程序的根组件。
  3. index.html:应用程序的入口文件。
  4. main.ts:应用程序的启动文件。

五、Angular 组件

1.组件概念

  • 组件是包含 HTML 模板、TypeScript 代码和 CSS 样式的独立单元,负责显示数据、处理用户输入和与其他组件交互。

2.创建组件

  • 使用ng generate component my-component可创建新组件,Angular CLI 会在src/app/下创建包含模板、代码和样式文件的文件夹。

3.组件模板

  • 定义组件外观和布局,可使用 Angular 的模板语法显示数据、绑定事件和使用指令。例如:
<div><h1>{{title}}</h1><p>{{description}}</p><button (click)="onClick()">Click me</button>
</div>

4.组件类

用 TypeScript 文件定义组件行为和逻辑,可定义属性、方法和生命周期钩子。例如:

import { Component } from '@angular/core';@Component({selector: 'app-my-component',templateUrl: './my-component.component.html',styleUrls: ['./my-component.component.css']
})
export class MyComponent {title = 'My Component';description = 'This is my component.';onClick() {console.log('Button clicked!');}
}

六、Angular 模块

  1. 模块概念:在 Angular 中,模块是组织代码的方式,将相关组件、服务、指令等组合在一起,形成独立功能单元,提高代码可维护性和可扩展性,方便复用。
    • declarations:声明模块中包含的组件、指令和管道。
    • imports:导入其他模块以使用其中功能。
    • providers:提供服务,可在模块中的组件注入使用。
    • exports:导出模块中的部分内容供其他模块使用。
  2. 模块代码示例:
import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { MyComponent } from './my-component/my-component.component';@NgModule({declarations: [MyComponent],imports: [CommonModule],exports: [MyComponent]
})
export class MyModule { }

七、Angular 路由配置方法

1.路由概念

  • 路由是 Angular 应用程序的导航机制,定义不同 URL 路径和对应的组件,让用户通过 URL 访问不同页面。

2.配置路由

  • 使用RouterModule.forRoot()方法配置路由。例如:
import { NgModule } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';
import { HomeComponent } from './home/home.component';
import { AboutComponent } from './about/about.component';const routes: Routes = [{ path: '', component: HomeComponent },{ path: 'about', component: AboutComponent }
];@NgModule({imports: [RouterModule.forRoot(routes)],exports: [RouterModule]
})
export class AppRoutingModule { }

3.路由参数

  • 可在路由中定义参数,在组件中通过注入ActivatedRoute服务获取参数值。例如:
const routes: Routes = [{ path: 'user/:id', component: UserComponent }
];import { Component } from '@angular/core';
import { ActivatedRoute } from '@angular/router';@Component({selector: 'app-user',templateUrl: './user.component.html',styleUrls: ['./user.component.css']
})
export class UserComponent {constructor(private route: ActivatedRoute) {}ngOnInit() {this.route.params.subscribe(params => {const id = params['id'];console.log(id);});}
}

4.路由导航守卫

  • 可控制用户导航行为,如在用户未登录时阻止访问某些页面。Angular 提供多种导航守卫,如CanActivateCanActivateChildCanDeactivate等。例如:
import { Injectable } from '@angular/core';
import { CanActivate, Router } from '@angular/router';@Injectable({providedIn: 'root'
})
export class AuthGuard implements CanActivate {constructor(private router: Router) {}canActivate(): boolean {if (isLoggedIn()) {return true;} else {this.router.navigate(['/login']);return false;}}
}
  • 在路由配置中使用导航守卫
const routes: Routes = [{ path: 'dashboard', component: DashboardComponent, canActivate: [AuthGuard] }
];

5.懒加载模块

  • 对于大型应用程序,可使用懒加载模块提高性能,只有在用户访问特定路由时才加载模块。
  • 创建懒加载模块:
import { NgModule } from '@angular/core';
import { Routes, RouterModule } from '@angular/router';
import { LazyComponent } from './lazy.component';const routes: Routes = [{ path: '', component: LazyComponent }
];@NgModule({imports: [RouterModule.forChild(routes)],declarations: [LazyComponent]
})
export class LazyModule { }
  • 在主路由配置中使用懒加载模块:
const routes: Routes = [{ path: '', component: HomeComponent },{ path: 'about', component: AboutComponent },{ path: 'lazy', loadChildren: () => import('./lazy.module').then(m => m.LazyModule) }
];

八、Angular 服务

1.服务概念

  • 服务是可复用代码块,可封装业务逻辑、数据访问等通用功能,在不同组件间共享。

2.创建服务

  • 使用ng generate service my-service创建服务,Angular CLI 会在src/app/下创建服务的 TypeScript 文件。

3.注入服务

  • 在组件中通过依赖注入获取服务实例。例如:
import { Component } from '@angular/core';
import { MyService } from './my-service.service';@Component({selector: 'app-my-component',templateUrl: './my-component.component.html',styleUrls: ['./my-component.component.css']
})
export class MyComponent {constructor(private myService: MyService) { }
}

4.使用服务

  • 服务可提供数据存储、网络请求等功能。例如:
import { Injectable } from '@angular/core';@Injectable({providedIn: 'root'
})
export class MyService {private data: string[] = [];addData(item: string) {this.data.push(item);}getData() {return this.data;}
}
  • 在组件中使用服务:
import { Component } from '@angular/core';
import { MyService } from './my-service.service';@Component({selector: 'app-my-component',templateUrl: './my-component.component.html',styleUrls: ['./my-component.component.css']
})
export class MyComponent {constructor(private myService: MyService) { }addItem() {const newItem = 'New item';this.myService.addData(newItem);console.log(this.myService.getData());}
}

九、Angular 表单处理

1.模板驱动表单

  • 通过在模板中使用表单指令实现表单验证和提交。例如:
<form #myForm="ngForm" (ngSubmit)="onSubmit(myForm)"><input type="text" name="username" ngModel required><input type="password" name="password" ngModel required><button type="submit">Submit</button>
</form>
  • 在组件中处理表单提交:
import { Component } from '@angular/core';@Component({selector: 'app-my-component',templateUrl: './my-component.component.html',styleUrls: ['./my-component.component.css']
})
export class MyComponent {onSubmit(form: any) {if (form.valid) {console.log(form.value);} else {console.log('Form is invalid');}}
}

2.响应式表单

  • 在组件类中创建表单模型实现表单验证和提交。例如:
import { Component } from '@angular/core';
import { FormGroup, FormControl, Validators } from '@angular/forms';@Component({selector: 'app-my-component',templateUrl: './my-component.component.html',styleUrls: ['./my-component.component.css']
})
export class MyComponent {myForm = new FormGroup({username: new FormControl('', Validators.required),password: new FormControl('', Validators.required)});onSubmit() {if (this.myForm.valid) {console.log(this.myForm.value);} else {console.log('Form is invalid');}}
}
  • 在模板中绑定表单模型:
<form [formGroup]="myForm" (ngSubmit)="onSubmit()"><input type="text" formControlName="username"><input type="password" formControlName="password"><button type="submit">Submit</button>
</form>

十、Angular 状态管理

1.状态管理概念

  • 在复杂应用程序中,多个组件可能需要共享和同步数据状态,状态管理用于管理应用程序状态,确保数据一致性和可维护性。

2.NgRx 状态管理库

  • NgRx 是流行的 Angular 状态管理库,基于 Redux 理念,提供可预测、可维护的方式管理应用程序状态,包含actions(定义动作)、reducers(根据动作更新状态)、effects(处理异步操作并触发动作)、selectors(从状态中选择特定数据)。例如:
  • 定义状态模型:
export interface AppState {counter: number;
}export const initialState: AppState = {counter: 0
};
  • 定义动作:
export const INCREMENT = 'INCREMENT';
export const DECREMENT = 'DECREMENT';export class IncrementAction implements Action {readonly type = INCREMENT;
}export class DecrementAction implements Action {readonly type = DECREMENT;
}
  • 定义 reducer:
import { AppState, initialState } from './app.state';
import { INCREMENT, DECREMENT } from './app.actions';export function reducer(state = initialState, action: any): AppState {switch (action.type) {case INCREMENT:return {...state, counter: state.counter + 1 };case DECREMENT:return {...state, counter: state.counter - 1 };default:return state;}
}
  • 在模块中配置 NgRx:
import { NgModule } from '@angular/core';
import { StoreModule } from '@ngrx/store';
import { reducer } from './app.reducer';@NgModule({imports: [StoreModule.forRoot({ appState: reducer })]
})
export class AppModule { }

十一、总结

本文介绍了 Angular 框架的基本概念、安装和使用方法,包括项目结构、组件、模块、路由配置、服务、表单处理和状态管理等方面。通过学习本文,可对 Angular 框架有初步了解,并能使用 Angular CLI 创建、开发和维护 Angular 应用程序。Angular 是功能强大的前端框架,若想深入学习,可参考 Angular 的官方文档和其他相关资源。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/56456.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

502 错误码通常出现在什么场景?

服务器过载场景 高流量访问&#xff1a;当网站遇到突发的高流量情况&#xff0c;如热门产品促销活动、新闻热点事件导致网站访问量激增时&#xff0c;服务器可能会因承受过多请求而无法及时响应。例如&#xff0c;电商平台在 “双十一” 等购物节期间&#xff0c;大量用户同时…

文生图的底层逻辑比你想象中简单!从大语言模型到大型多模态模型的演进与展望

2024年8月15日&#xff0c;来自浙江农林大学&#xff08;数学与计算机科学学院&#xff09;冯海林团队在CMC期刊发表名为“Evolution and Prospects of Foundation Models: From Large Language Models to Large Multimodal Models”的文章。在这篇文章中&#xff0c;研究团队首…

铲屎官们快来交作业!双十一性价比高的宠物空气净化器求推荐?

好不容易等到一年一度的双十一&#xff0c;这个购物狂欢节我肯定不能错过。除了自己买买买外&#xff0c;还准备给我家小猫也买个礼物。之前听说宠物空气净化器对养宠家庭作用很大&#xff0c;打算趁活动拿下。 不看不知道&#xff0c;一看吓一跳&#xff0c;有点太贵了吧&…

【SoC】被忽略的reset结构设计

1024这天爆出来的设计失误&#xff0c;真的很应景啦&#xff01; 先献上A72的reset结构图吧&#xff0c;虽然最终的解决方案不是按照这个来的&#xff0c;不过也给了一个相对较清晰的reset架构了。 异步复位树 当对整个电路进行复位的时候&#xff0c;使用异步复位&#xff0c…

spark统一内存模型 详解

Apache Spark 是一个用于大规模数据处理的分布式计算框架&#xff0c;它支持多种处理模型&#xff08;如批处理、流处理、SQL、机器学习等&#xff09;。为了高效地在分布式环境中处理这些多样化的工作负载&#xff0c;Spark 在 2.x 版本后引入了统一内存管理模型&#xff0c;以…

ubuntu安装mysql8,离线安装mysql8

1、mysql官网下载安装包&#xff0c;版本号以实际下载为准 https://dev.mysql.com/downloads/mysql/ 如&#xff1a; mysql-server_8.0.40-1ubuntu24.04_amd64.deb-bundle.tar 2、上传到服务器 如 /opt/目录 3、创建一个mysql目录解压 mkdir mysql & tar -xvf mysql-server…

【实战项目】——Boost搜索引擎(五万字)

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 目录 前言 一、项目的相关背景 1.1、什么是Boost库&#xff1f; 1.2、什么是搜索引擎&#xff1f; 1.3、为什么要做Boost库搜索引擎&#xff1f; 二、搜索引擎的宏观原…

10.24Python_pandas_基础

一、基础 1、概述 Pandas 是一个开源的第三方 Python 库&#xff0c;从 Numpy 和 Matplotlib 的基础上构建而来Pandas 名字衍生自术语 “panel data”&#xff08;面板数据&#xff09;和 “Python data analysis”&#xff08;Python 数据分析&#xff09;Pandas 已经成为 P…

ansible面试题

简述Ansible及其优势&#xff1f; Ansible 是一款极其简单的开源的自动化运维工具&#xff0c;基于Python开发&#xff0c;集合了众多运维工具(puppet,cfengine, chef, func, fabric)的优点。实现了批量系统配置&#xff0c;批量程序部署&#xff0c;批量运行命令等功能。同时…

生产小工单如何轻松实现生产任务敏捷管理的?

在现代生产任务制造业中&#xff0c;有效管理生产是提升效率的关键。生产管理系统中的生产小工单管理&#xff0c;是解决传统生产管理痛点的重要工具。本文将深入探讨生产小工单的概念、流程及其主要功能。 下面我会用一个实际的生产工单系统为例&#xff0c;给大家详细介绍下…

苍穹外卖--开发记录day12(完结篇)

目录 苍穹外卖day12一&#xff1a;工作台二&#xff1a;apachePOI三&#xff1a;导出excel报表&#xff08;最后一个功能&#xff01;&#xff01;&#xff09; 总结&#xff08;项目完结心得&#xff09; 苍穹外卖day12 一&#xff1a;工作台 代码导入之后就是这样的效果&…

Java 虚拟机(JVM)中的内存泄漏排查技巧及各种内存查看命令分析工具推荐

文章目录 引言什么是内存泄漏&#xff1f;工具和技术1. 使用 jstat 监控 JVM2. 使用 jmap 生成堆转储文件3. 使用 jvisualvm 分析堆转储文件4. 使用 MAT&#xff08;Memory Analyzer Tool&#xff09;5. 使用 YourKit 或 JProfiler6. 代码审查和静态分析 实战案例案例 1&#x…

使用U-KAN训练自己的数据集 — 医疗影像分割

<U-KAN Makes Strong Backbone for Medical Image Segmentation and Generation> U-Net已成为各种视觉应用的基石,如图像分割和扩散概率模型。虽然通过整合变压器或mlp引入了许多创新设计和改进,但网络仍然局限于线性建模模式以及缺乏可解释性。为了应对这些挑战,受到…

数据库框架GORM快速入门【干货】

1.安装依赖 &#xff08;1&#xff09;安装GORM框架 go get -u gorm.io/gorm&#xff08;2&#xff09;安装不同的数据库驱动&#xff08;根据实际情况选择&#xff09; go get -u gorm.io/driver/mysql go get -u gorm.io/driver/postgres go get -u gorm.io/driver/sqlite …

ChartCheck: Explainable Fact-Checking over Real-World Chart Images

论文地址: https://aclanthology.org/2024.findings-acl.828.pdfhttps://aclanthology.org/2024.findings-acl.828.pdf 1.概述 事实验证技术在自然语言处理领域获得了广泛关注,尤其是在针对误导性陈述的检查方面。然而,利用图表等数据可视化来传播信息误导的情况却很少受到…

【简历】25届浙江某211大学JAVA简历:明明项目有货,但是长篇大论减分!!

注&#xff1a;为保证用户信息安全&#xff0c;姓名和学校等信息已经进行同层次变更&#xff0c;内容部分细节也进行了部分隐藏 另外&#xff1a;我们出这一系列校招简历指导的原因&#xff0c;就是看很多学生被忽悠&#xff0c;没有先定位大厂、中厂还是小公司&#xff0c;导…

京准电钟HR-901GB双GPS北斗卫星时钟服务器

京准电钟HR-901GB双GPS北斗卫星时钟服务器 京准电钟HR-901GB双GPS北斗卫星时钟服务器 作为国家电力系统最重要的设备之一,卫星时间同步装置随着电力行业的发展不断有了新的要求,从单纯的具备时间数据输出能力,发展到装置状态信息上送、对用时设备的对时质量进行监测,确保站点内…

Logistic回归(分类)问题探讨与实践

说明 在本专栏机器学习_墨#≯的博客-CSDN博客之前的博文中&#xff0c;已经对感知机[1]、SVM[2]以及线性回归问题[3]做过探讨和实践。感知机以及SVM是用来做分类的&#xff0c;线性回归是用来做拟合的。本文将要探讨的Logistic回归(逻辑回归)则是使用线性回归的方法来做分类(二…

90V转5V4A同步降压芯片WT6037

90V转5V4A同步降压芯片WT6037 WT6037 被定义为一款高压同步降压转换器&#xff0c;其设计可在 10V 至 90V 的宽泛工作电压区间内稳定运行。该转换器尤其适用于需承受宽电压输入范围的电池组系统&#xff0c;诸如 12V 至 72V 的电池组&#xff0c;以及 60V 至 90V 的降压应用场…

docker搭建etcd集群环境方式

docker搭建etcd集群环境方式 from: etcd 虚拟机与docker搭建etcd集群环境方式_docker部署etcd集群-CSDN博客 windows系统下 1: “\”要换成&#xff1a;“^” 2: 不能在windows powershell下执行