Angular4中的组件、模块、服务、装饰器、控制器

一、组件

Angular4具有组件化的特性,不同于之前的AngularJS用户看到的是View,Angular4将组件组成一棵树,用户看到的是这棵组件树中被激活的组件(component)。
所谓组件,我们可以将它理解为一段带有业务逻辑和数据的HTML。

二、服务

服务(server)用来封装可重用的业务逻辑

三、指令

指令允许你向HTML元素中添加自定义行为。Angular为我们提供了很多指定可以使用。

四、模块

上面说的组件,服务,指令加在一起是用来实现一个功能的,而模块(module)是用来打包和分发这些功能的。

五、举例

这里我们使用Angular CLI为我们自动生成的项目中的组件和模块为例。
先看src目录中的app中的app.components.ts,这是一个Typescript文件。内容如下:

import { Component } from '@angular/core';

@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent {
  title = 'app works!';
}

这里需要介绍一下组件中的三个必备要素:

1、装饰器

这段代码中的@Components就是一个装饰器,它用来告知Angular框架来如何处理一个Typescript类。它包含多个属性,这些属性值叫做元数据。Angular会根据元数据渲染组件,并执行组件逻辑。
简单的说就是我们可以看到这段代码的后三行定义了一个AppComponent类,它看着就是一个普通的ts类,但是我们需要告诉Angular这个类是一个组件,这就需要用装饰器将这些元数据附加到类上。元数据会告诉Angular图和将这个Typescript类处理成一个组件。

元数据:

(1)selector: 'app-root'
这段代码表示这个组件可以通过app-root这个html标签来调用。打开项目根目录下的index.html可以看到里面有这样一行代码
<app-root>Loading...</app-root>
这其实就是调用了我们的这个组件
(2)templateUrl: './app.component.html'
既然已经知道了怎么调用组件,这行代码就是用来说明组件显示的内容是什么。打开app.component.html代码如下

<h1>
  {{title}}
</h1>
那这里的{{tilte}}是什么意思呢?后面马上说到。

(3)styleUrls: ['./app.component.css']
这个和上面的类似,表示组件的css

2、模板(template)

模板用来定义组件的外观,元数据中的templateUrl指定的文件其实就是组件的模板。

3、控制器(controller)

控制器包含了组件的所有属性和方法,用来定义页面 逻辑。这段代码的后三行定义的类,其实就是定义了一个控制器。

export class AppComponent {
  title = 'app works!';
}

控制器和模板进行数据绑定,也就是说我们之前在app.component.html中看到的{{title}}中的title就是控制器中的title,这里的双大括号是数据绑定的一种方式。