Angular2入门-架构总览

▓▓▓▓▓▓ 大体介绍

  在3月23日,Angular4正式发布(没有3)。彷佛如今学Angular2又晚了,又晚一步-_-||。Angular2在Angular1的基础上有了较大的改变。以前向一个同窗(以前学过Angular1)问一个Angular2的问题,他反问到这是Angular代码? 可见Angular1->Angular2的变化有多大。先来看看Angular2的架构浏览器

 

▓▓▓▓▓▓ 核心模块

  一个完整的Angular应用主要由六个重要部分组成:组件模板指令服务依赖注入路由服务器

  他们之间的关系:架构

  从图中能够看出:框架

    一、与用户交互的是模板视图,模板和组件类共同组成组件函数

    二、路由是控制组件的建立和销毁,从而驱使界面切换spa

    三、指令和模板相关联,扩展了模板的语法设计

    四、服务是封装若干个功能逻辑的单元,经过依赖注入引入组件内部3d

 

▓▓▓▓▓▓ 组件

  Angular框架是基于组件设计,组件负责控制屏幕上的一小块区域,例如网页的导航栏就是一个组件日志

  一个组件的代码:code

import { Component, Input } from '@angular/core';
import { Hero } from './hero';

@Component({
    selector: 'my-hero-detail',
    template: `
        <div *ngIf="hero">
          <h2>{{hero.name}} details!</h2>
          <div><label>id: </label>{{hero.id}}</div>
          <div>
            <label>name: </label>
            <input [(ngModel)]="hero.name" placeholder="name"/>
          </div>
        </div>
    `
})

export class HeroDetailComponent {
    @Input()
    hero: Hero;
}

 

 

 

▓▓▓▓▓▓ 模板

  咱们经过组件的自带的模板来定义组件视图。模板以 HTML 形式存在,告诉 Angular 如何渲染组件。

  例如上面组件中的@Component中就是模板

@Component({
    selector: 'my-hero-detail',
    template: `
        <div *ngIf="hero">
          <h2>{{hero.name}} details!</h2>
          <div><label>id: </label>{{hero.id}}</div>
          <div>
            <label>name: </label>
            <input [(ngModel)]="hero.name" placeholder="name"/>
          </div>
        </div>
    `
})

 

▓▓▓▓▓▓ 指令

  指令和模板的关系密切,指令能够与DOM进行灵活交互,能够改变样式也能够修改DOM。通常的指令都做用在已有的DOM元素上

  一、修改DOM

<button *ngIf="canEdit">编辑</button>

  当canEdit为true时,button会显示,不然,button隐藏

 

  二、改变元素样式

<button [ngStyle]="setStyles()">编辑</button>

  setStyles()是一个函数,能够经过这个函数修改元素的样式

 

▓▓▓▓▓▓ 服务

  服务是封装单一功能的单元,常被引用于组件内部,做为组件的功能扩展。它能够是一个简单的字符串或是JSON数据,也能够是一个函数甚至是一个类

  组件自己不从服务器得到数据、不进行验证输入,也不直接往控制台写日志。 它们把这些任务委托给服务。

  一个简单的服务(包含一个类):

export class Hero {
    id: number;
    name: string;
}

 

▓▓▓▓▓▓ 依赖注入

  经过依赖注入机制,服务等模块能够被引入到任何一个组件中,而开发者无需关心这些模块是如何被初始化的。由于Angular已经帮你处理好了,包括本模块自己依赖的其余模块也会被初始化

 

▓▓▓▓▓▓ 路由

  路由它把浏览器中的URL看作一个操做指南, 据此导航到一个由客户端生成的视图,并能够把参数传给支撑视图的相应组件,帮它决定具体该展示哪些内容。 咱们能够为页面中的连接绑定一个路由,这样,当用户点击连接时,就会导航到应用中相应的视图。 当用户点击按钮、从下拉框中选取,或响应来自任何地方的事件时,咱们也能够在代码控制下进行导航。 路由器还在浏览器的历史日志中记录下这些活动,这样浏览器的前进和后退按钮也能照常工做。

 

参考资料:

   揭秘Angular2第3章 

   TypeScript Handbook(中文版)

相关文章
相关标签/搜索