博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Angular 4.0 架构详解
阅读量:7091 次
发布时间:2019-06-28

本文共 1907 字,大约阅读时间需要 6 分钟。

这个架构图展现了 Angular 应用中的 8 个主要构造块:

  • 模块 (module)

  • 组件 (component)

  • 模板 (template)

  • 元数据 (metadata)

  • 数据绑定 (data binding)

  • 指令 (directive)

  • 服务 (service)

  • 依赖注入 (dependency injection)

1.模块 (module)

Angular 或者 ionic 新建的项目,都会存在一个根模块,默认名是 AppModule。如果你使用了模块化来创建应用,包括 AppModule,每个都会存在一个 @NgModule 装饰器的类(虽然他很像 java 中的注解,但是他的官方命名叫装饰器)。我们新建的页面,如果不使用懒加载,都要在 @NgModule 中先声明后使用

下面举个例子,简单介绍一下 @NgModule 中的内容:

//app.module.tsimport { NgModule }      from '@angular/core';import { BrowserModule } from '@angular/platform-browser';@NgModule({  imports:      [ BrowserModule ],  providers:    [ Logger ],  declarations: [ AppComponent ],  exports:      [ AppComponent ],  bootstrap:    [ AppComponent ]})export class AppModule { }
  • imports 本模块声明的组件模板需要的类所在的其它模块。

  • providers 服务的创建者,并加入到全局服务列表中,可用于应用任何部分。

  • declarations 声明本模块中拥有的视图类。Angular 有三种视图类:组件、指令和管道

  • exports declarations 的子集,可用于其它模块的组件模板。

  • bootstrap 指定应用的主视图(称为根组件),它是所有其它视图的宿主。只有根模块才能设置 bootstrap 属性。

2.组件 (component)、模板 (template)、元数据 (metadata)

Component 

组件是一个装饰器,他能接受一个配置对象, Angular 会基于这些信息创建和展示组件及其视图。

  • selector:CSS 选择器,它告诉 Angular 在父级 HTML 中查找 <hero-list> 标签,创建并插入该组件。

  • templateUrl:组件 HTML 模板的模块相对地址,如果使用 template 来写的话是用“`”这个符号来直接编写 HTML 代码。

  • providers:组件所需服务的依赖注入。

template 

模板就是那段 HTML 代码,可以用 templateUrl 引入外面的,也可以用 template`` 直接写。

metadata 

元数据装饰器用类似的方式来指导 Angular 的行为。 例如 @Input、@Output、@Injectable 等是一些最常用的装饰器

3.数据绑定 (data binding)

//插值表达式    显示组件的hero.name属性的值
  • {
    {hero.name}}
  • //属性绑定 把父组件selectedHero的值传到子组件的hero属性中
    //事件绑定 用户点击英雄的名字时调用组件的selectHero方法
  • //双向绑定 数据属性值通过属性绑定从组件流到输入框。用户的修改通过事件绑定流回组件,把属性值设置为最新的值
    1. 双花括号是单向绑定,传递的是值。方向是 组件 -> 模板

    2. 方括号是单向绑定,传递的是属性。方向是 父组件 -> 子组件

    3. 圆括号是事件绑定,处理点击等活动(action)

    4. 方括号套圆括号是双向绑定,方向是 组件 <-> 模板

    4.指令 (directive)

    结构型指令是 ngFor、ngIf 这种的,通过在 DOM 中添加、移除和替换元素来修改布局。

    属性型指令是 ngModel 这种的,用来修改一个现有元素的外观或行为。

    Angular 还有少量指令,它们或者修改结构布局(例如 ngSwitch ), 或者修改 DOM 元素和组件的各个方面(例如 ngStyle 和 ngClass)

     

    转载于:https://www.cnblogs.com/Nyan-Workflow-FC/p/7756177.html

    你可能感兴趣的文章
    Windows Server 2012之Windows PowerShell Web(4)
    查看>>
    MimbleWimble 系列之Pedersen 承诺
    查看>>
    css——简单模版
    查看>>
    Spring(一)——总体介绍
    查看>>
    搭建简单的DHCP服务 (照着敲就能搭建好)
    查看>>
    select count(*)和select count(1)的区别
    查看>>
    Spring AOP实现对redis统一管理 (注解方式)
    查看>>
    【MVVM】- Avalon 数组操作
    查看>>
    【VMCloud云平台】SCSM(八)SCSM创建请求产品
    查看>>
    我的友情链接
    查看>>
    虚拟机的时间同步
    查看>>
    在XenServer 6.0中设置自动启动虚拟机
    查看>>
    【大数据培训】大数据带你寻找“惊心动魄”
    查看>>
    TCP三次握手与四次挥手
    查看>>
    vRealize Operations Manager 6.5的安装与配置
    查看>>
    centos7修改网卡一致性命名
    查看>>
    文件管理命令及变量基础
    查看>>
    find
    查看>>
    如何理解磁力
    查看>>
    安卓学习-NDK开发
    查看>>