2016-08-25, 当前版本是 RC 5.

参考 : https://angular.cn/docs/ts/latest/guide/ngmodule.html

提醒 : 这系列笔记的 "ng" 指的是 angular2 哦!

ECMA 6 中, 每一个 .js 文件都是一个模块.

ng 中的模块则指的是一组被封装起来的组件, 指令, 管道, 它们可以来自不同的 .js 文件.

所以 ng 模块可以说是 ECMA 模块的更上一层封装. 这正是我们需要的.

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

@NgModule({
imports: [],
declarations: [],
exports: [],
bootstrap: [],
providers : []
})
export class AppModule { }

  

大概长这样.

imports 顾名思义, 就是导入其它的模块,这和 ECMA 模块是一样的概念.

declarations : [ProductComponent, ProductPipe, ProductDirective] declarations 是用来声明当前这个模块所具有的组件, 指令, 管道的. ( 组件如果没有被声明是不能用的哦,会报错的. )

exports : [ImportedModule, DeclaredComponent] 我们想导出什么就写什么, 默认情况下所有导入和声明的模块或组件都是私有的. 除非我们导出它们.

以上3项很好理解.

需要注意, 如果一个组件已经被"声明"过了,请不要再次"声明"它, 比如 : 模块A 声明了 组件A, 而 模块B 导入了 模块A, 那么在 模块B 中就可以使用 组件A 了, 不需要在 模块B 中"再次声明", 即使你再声明也无效

bootstrap: [AppComponent] 只有在主模块 AppModule 会使用到.

在 main.js 中启动主模块

import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';
import { AppModule } from './app.module'; platformBrowserDynamic().bootstrapModule(AppModule);

这是动态的方式, 还有一个静态的方式, 有兴趣可以去参考

providers : [ProductService]

模块的 providers 会注册进根注入器中. 意味着这是全局的. (lazyload module 例外, 因为 lazyload 的 module 会是 root module 的 child)

例如 : (we have 3 module : A,B,C ) A import B,C -> C can use B service, even C not import B

所以, 如果你只想在某个 module 内使用某个 service 的话, 那写在 component.providers 吧. 但其实把所有provider 定义全局也没很大的问题, 毕竟 provider 都是 class or token 不会有命名冲突的问题.

ng 有个延迟加载 module 的功能叫 lazy load, 它是配合 router 一块使用的.

lazy load 会创建子注入器, 这个要留意哦, 它会影响到 providers (原本 module's providers 是注册到 root injector 的),

ng给出的理由是, 注入器一旦开始工作就不能修改了, 所以 lazyload 只能通过创建子注入器来扩展.

所以, 一般上 lazy load 的 module 需要声明 providers 的话, 会这样做.

这个做法是这样的, 不把 providers 声明到 @NgModule 里面, 而是提供一个静态方法给 root module import.

或则你可以把 providers 独立写成另一个模块.

特性模块

特性模块和根模块是差不多的,也是有根组件,路由等等

区别如下

1.不会有 bootstrap: [AppComponent]

2.不会有 BrowserModule, 取而代之的是 CommonModule

@NgModule({
imports: [
CommonModule,
routing
],
declarations: [
ProductComponent
],
providers: [routingProviders]
})
export class ProductModule { }

之前说的 forRoot 还有扩展模块的好处, 可以看到 import module 时可以通过一个带参数的方法, 那样我们就可以依据不同的项目去设定或则扩展我们的模块了. (类似 ng1 的 app.config)

有一个叫 entryComponents 的属性, 他和 declarations 不一样的地方是, 它是专门用来定义动态组建的. 动态组建是通过 class 来创建的不是写在 html 里的. 如果我们没有告诉 ng 我们有什么动态的 component 的话, 那么在 aot 的时候就没办法预编辑了.

更新 : 2017-01-26

module 可以不需要 import 直接 export 其它 module, 这和 ecma module 是一样的.

angular2 学习笔记 ( ngModule 模块 )的更多相关文章

  1. Angular2学习笔记——NgModule

    在Angular2中一个Module指的是使用@NgModule修饰的class.@NgModule利用一个元数据对象来告诉Angular如何去编译和运行代码.一个模块内部可以包含组件.指令.管道,并 ...

  2. Python学习笔记—itertools模块

    这篇是看wklken的<Python进阶-Itertools模块小结> 学习itertools模块的学习笔记 在看itertools中各函数的源代码时,刚开始还比较轻松,但后面看起来就比较 ...

  3. Python学习笔记之模块与包

    一.模块 1.模块的概念 模块这一概念很大程度上是为了解决代码的可重用性而出现的,其实这一概念并没有多复杂,简单来说不过是一个后缀为 .py 的 Python 文件而已 例如,我在某个工作中经常需要打 ...

  4. Python3学习笔记25-logging模块

    logging模块,Python自带用来记录日志的模块. 因为工作需要用到关于日志的,最近一直都在看关于日志模块的东西,百度了很多文章,可惜都是看的让人一头雾水,最后运气不错,找到一篇很详细的文章.传 ...

  5. Angular2学习笔记(1)

    Angular2学习笔记(1) 1. 写在前面 之前基于Electron写过一个Markdown编辑器.就其功能而言,主要功能已经实现,一些小的不影响使用的功能由于时间关系还没有完成:但就代码而言,之 ...

  6. Angular2 小贴士 NgModule 模块

    angular2 具有了模块的概念,响应了后台程序的号召,高内聚 低耦合.模块就是用来进行封装,进行高内聚  低耦合的功能. 其实各人认为ng2 的模块和.net的工程类似,如果要使用模块中定义的功能 ...

  7. Angular2学习笔记2

    每个angular2应用程序默认使用app目录来创建(可以自己制定,但是eclipse插件生成的会自动使用app) 每个程序应当至少有一个angular模块即根模块.根模块使用@NgModule({} ...

  8. Angular2学习笔记(1)——Hello World

    1. 写在前面 之前基于Electron写过一个Markdown编辑器.就其功能而言,主要功能已经实现,一些小的不影响使用的功能由于时间关系还没有完成:但就代码而言,之前主要使用的是jQuery,由于 ...

  9. Angular2学习笔记——路由器模型(Router)

    Angular2以组件化的视角来看待web应用,使用Angular2开发的web应用,就是一棵组件树.组件大致分为两类:一类是如list.table这种通放之四海而皆准的通用组件,一类是专为业务开发的 ...

随机推荐

  1. [Java] Java 技术和 JVM 基础

    Java 由 Sun 公司在 1995 首次发布,既是一门编程语言,也是一个计算平台. Java 运行时版本 Java Runtime Edition 当你下载 Java 完时候,你会得到一个 Jav ...

  2. Shopilex - 开源免费网店系统

    Shopilex - 开源免费网店系统 Shopilex是一套基于GPL开源协议的,MVC架构的开源电子商务网店系统,是目前中文领域里真正开源免费的网店系统.

  3. 史上最全maven pom.xml详解

    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/20 ...

  4. Django 数据库查询

    #!/usr/bin/python #coding:utf-8 from django.shortcuts import render; from django.shortcuts import re ...

  5. vector容器经常用法

    容器简单介绍 定义及初始化 末尾插入元素 遍历 size 函数是能够动态添加的 通过下标操作添加改变vector内容不是安全的操作 仅能对已存在元素进行下标操作不存在会crash 将元素一个容器复制给 ...

  6. 使用Httpwatch分析响应时间--转

    时间片段名称 意思 Blocked (阻塞)灰色 阻塞的时间主要包括,预处理时间,(如缓存查找)和网络排队等待的时间,导致阻塞最主要的原因是下载页面中的图片 DNS Lookup(域名解释)紫色 域名 ...

  7. 源代码解读Cas实现单点登出(single sign out)功能实现原理--转

    关于Cas实现单点登入(single sing on)功能的文章在网上介绍的比较多,想必大家多多少少都已经有所了解,在此就不再做具体介绍.如果不清楚的,那只能等我把single sign on这块整理 ...

  8. 大数据笔记03:大数据之Hadoop的安装

    1.安装Hadoop (1)准备Linux环境 (2)安装JDK (3)配置Hadoop 2.准备Linux环境 (1)我们用户可能都是使用Windows环境,一般用户都是先安装虚拟机,然后在虚拟机上 ...

  9. 几个常用的ps命令

    1. ps aux If you are looking for a short summary of the active processes, use  ps aux [root@rhel7 tm ...

  10. 递归---NYOJ-176 整数划分(二)和NYOJ-279队花的烦恼二

    这道题目的递归思想和第一个题差不多, 主要思想是:func(n, m)的作用是将n划分为m个. 1. 如果n < m 的时候肯定是不能划分的,所以就返回0 2. 如果m = 1 或者 n = m ...