历史: javascript
Angular是Google推出的Web前端开发框架,从12年发布起就受到了强烈的关注,他首次提出了双向绑定的概念,让人耳目一新。html
Angular 2特性前端
就在2016年9月中旬,时隔4年,Google正式发布了Angular的第二代开发框架Angular 2,2017年3月推出了Angular4。Angular 5 出来了,不过你也不用太过担忧,由于不管是Angular 4 仍是Angular 5,其内核依然是Angular 2。从 2.0 版本开始出的新版本会保持向后兼容,不会出现 1 到 2 这么大的变化.java
这个架构图展示了 Angular 应用中的 8 个主要构造块:bootstrap
Angular 应用是模块化的,而且 Angular 有本身的模块系统,它被称为 Angular 模块或 NgModules。架构
Angular 或者 Ionic 新建的项目,都会存在一个根模块,默认名是 AppModule。若是你使用了模块化来建立应用,包括 AppModule,每一个都会存在一个 @NgModule 装饰器的类(很像 java 中的注解,但官方命名叫装饰器)。新建的页面,若是不使用懒加载,都要在
@NgModule
中先声明后使用
。app
//app.module.ts import { NgModule } from '@angular/core'; import { BrowserModule } from '@angular/platform-browser'; @NgModule({ imports: [ BrowserModule ], providers: [ Logger ], declarations: [ AppComponent ], exports: [ AppComponent ], bootstrap: [ AppComponent ] }) export class AppModule { }
//hero-list.component.ts @Component({ selector: 'hero-list', templateUrl: './hero-list.component.html', providers: [ HeroService ] }) export class HeroListComponent implements OnInit { /* . . . */ }
组件就是一个类,是Angular的核心。@Component 是组件元数据装饰器,用来修饰一个组件,他能接受一个配置对象, Angular 会基于这些信息建立和展现组件及其视图。
metadata
元数据装饰器用相似的方式来指导 Angular 的行为。 例如 @Input、@Output、@Injectable 等是一些最经常使用的装饰器。框架
这里一共展现四种数据绑定,看一下示例代码:dom
//插值表达式 显示组件的hero.name属性的值1)
<li>{{hero.name}}</li>
//属性绑定 把父组件selectedHero的值传到子组件的hero属性中,也能够把组件中的属性绑定到模板中元素的dom属性上。2)
<hero-detail [hero]="selectedHero"></hero-detail>
//事件绑定 用户点击英雄的名字时调用组件的selectHero方法3)
<li (click)="selectHero(hero)"></li>
//双向绑定 数据属性值经过属性绑定从组件流到输入框。用户的修改经过事件绑定流回组件,把属性值设置为最新的值4)
<input [(ngModel)]="hero.name">
严格来讲组件就是一个指令
,可是组件很是独特,并在 Angular 中位于中心地位,因此在架构概览中,咱们把组件从指令中独立了出来。
咱们这里提到的指令有两种类型:
结构型 structural 指令和属性 attribute 型指令。ide
1) 结构型指令是 ngFor、ngIf 这种的,经过在
DOM
中添加、移除和替换元素来修改布局。
2) 属性型指令是 ngModel 这种的,用来修改一个现有元素的外观或行为。
Angular 还有少许指令,它们或者修改结构布局(例如 ngSwitch ), 或者修改 DOM 元素和组件的各个方面(例如 ngStyle 和 ngClass)。
服务是用来封装可重用的业务逻辑
依赖注入是提供类的新实例的一种方式,还负责处理类所需的所有依赖。大多数依赖都是服务。 Angular 使用依赖注入来提供新组件以及组件所需的服务。
好比咱们要给某组件导入HeroService这个服务,看这段代码:
constructor(private service: HeroService) {
...
}
这个constructor就是构造函数
,依赖注入在 constructor 中进行。前面写上 private、public(在构造函数内写上public会自动建立类的成员变量),这是 TypeScript 语法。
当 Angular 建立组件时,会首先为组件所需的服务请求一个注入器 injector。咱们必须先用注入器 injector 为 HeroService 注册一个提供商 provider(服务)。
看一下下面的代码,意思就是咱们必须在 providers 写上才能用(若是不在组件中注册,则须要在模块中注册)
@Component({ selector: 'hero-list', templateUrl: './hero-list.component.html', providers: [ HeroService ] })
依赖注入主要用来导入服务。
---------refrence--------------
Angular中文文档 https://www.angular.cn/docs
https://i.cnblogs.com/EditPosts.aspx?opt=1
TypeScript中文文档 (https://www.tslang.cn/docs/handbook/basic-types.html)