本文呢主要给大家介绍的关于Angular2模块和组件的相关内容,分享出来供大家参考学习,下面来一起看看详细的介绍:
一、初步了解模块和组件
之前给大家介绍了构建工程,这篇文章简单讲述一下Angular2中的模块和组件。
app文件夹下有五个文件,其中,app.component.spec.ts应该是和模块测试有关的文件,目前不用管它。剩下的四个文件就是典型的模块+组件的文件组成模式。
Angular2应用由模块和组件构成,每个模块这样明明name.module.ts,组件则是name.component.ts。
这几个文件的关系是从属关系:
|--app.module.ts(模块) "htmlcode"><div> <my-app><my-app>//可以像原生标签一样添加属性,而且组件能接收的属性更丰富 //标签里面也可以放内容 </div>组件其实是一个类,它定义了一系列方法和属性,并且把HTML模板封装起来。它的意义是,你可以把它当做一个独立的隔离的盒子,并利用其中的方法和属性进行盒子内部的操作,以及和外界的父组件、兄弟组件交互。
1.2模块的含义
模块就是将一系列的组件还有指令、服务整合封装到一起,提供一个完整的功能。模块可以被外部模块引用。
二、模块详解和根模块
2.1 根模块
每个应用会有一个根模块,按照约定,它的类名叫做AppModule,被放在app.module.ts文件中。应用启动时,就会加载这个模块。
每个根模块会有一个根组件,默认就是app.component.ts,名字是app-root。
查看项目目录中的index.html,会发现有
<app-root>Loading...</app-root>
这样的代码,就是在加载这个根模块。2.2 模块详解
下面是app.module.ts的代码。
import { BrowserModule } from '@angular/platform-browser';//每个在浏览器中运行 //的应用的根模块都需要引入BrowserModule import { NgModule } from '@angular/core';//每个模块都需要引入的核心库中的NgModule import { FormsModule } from '@angular/forms';//表单模块,在应用中使用表单时引入 import { HttpModule } from '@angular/http';//http模块,当需要进行http远程请求时引入 import { AppComponent } from './app.component';//自己创建的组件 @NgModule({ declarations: [ AppComponent ], imports: [ BrowserModule, FormsModule, HttpModule ], providers: [], bootstrap: [AppComponent] }) export class AppModule { }Angular2用TypeScript组织代码的方式大致就像这个文件一样。
1、在顶部使用import语句,导入模块或者组件需要使用的外部模块。
在模块中需要使用自己创建的组件或者其他服务、指令,也需要import。
2、import语句之后,使用
@NgModule()
语句描述本模块的元数据。
- declarations:声明属于本模块的组件,每个组件必须在且仅在一个模块中声明。
- imports:引入买本模块中用到的模块,该模块是处于import语句引入的模块中。
- providers:声明模块中使用的服务的提供者,暂时还没有用到。
- bootstrap:根模块中的引导组件,应用启动过程中,会创建这个数组中的组件并插入到HTML中,一般只有一个引导组件。
3、最后,使用export语句,创建模块的类并暴露出去。
模块、组件只有暴露出去,其他的模块才能引用。
三、组件详解
import { Component } from '@angular/core'; //所有组件必须引入 @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { title = 'app works! 你已经完成了第一步'; }
1、import语句导入需要的模块。
2、使用@Component()
来描述本组件的元数据。
- selector:创建的组件的名字,就像HTML标签的名字一样
- templateUrl: HTML模板,使用相对路径,./表示这个组件文件所在的当前目录,
- styleUrls:HTML模板使用的样式表,可以有多个。
3、最后,使用export创建组件的类并暴露出去。在类中,可以创建属性和方法。
四、应用启动过程
整个应用的启动流程:加载根模块,加载所需的其他模块,创建引导组件,显示组件内容。
注意:我觉得学习Angular2很好的方法之一就是去看官方教程,有中文版的,很方便。看完前面的开发指南部分就足以了解Angular2的大致原理了,当然官方教程有的地方概念可能很模糊,有地方不了解的同学,可以留言交流,谢谢大家对的支持。
好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 好薇2024《兵哥哥》1:124K黄金母盘[WAV+CUE]
- 胡歌.2006-珍惜(EP)【步升大风】【FLAC分轨】
- 洪荣宏.2014-拼乎自己看【华特】【WAV+CUE】
- 伊能静.1999-从脆弱到勇敢1987-1996精选2CD【华纳】【WAV+CUE】
- 刘亮鹭《汽车DJ玩主》[WAV+CUE][1.1G]
- 张杰《最接近天堂的地方》天娱传媒[WAV+CUE][1.1G]
- 群星《2022年度发烧天碟》无损黑胶碟 2CD[WAV+CUE][1.4G]
- 罗文1983-罗文甄妮-射雕英雄传(纯银AMCD)[WAV+CUE]
- 群星《亚洲故事香港纯弦》雨果UPMAGCD2024[低速原抓WAV+CUE]
- 群星《经典咏流传》限量1:1母盘直刻[低速原抓WAV+CUE]
- 庾澄庆1993《老实情歌》福茂唱片[WAV+CUE][1G]
- 许巍《在别处》美卡首版[WAV+CUE][1G]
- 林子祥《单手拍掌》华纳香港版[WAV+CUE][1G]
- 郑秀文.1997-我们的主题曲【华纳】【WAV+CUE】
- 群星.2001-生命因爱动听电影原创音乐AVCD【MEDIA】【WAV+CUE】