Angular2 入门
1. 说明
该文档为Angular2的入门文档,可以根据该文档的内如做出一个“helloworld”类型的Angualr2入门程序,通过该文档可以初步了解Angular2的相关知识以及开发流程,同时搭建一套可用的开发环境。
环境:
node v6.2.2
typescript v1.8.2
angular2 rc4
visual studio code
2. 环境安装
如果机器上还木有node环境,请安装最新的node环境。
3. 创建并配置
3.1 创建项目目录
创建一个文件夹 名称为 ng2-helloworld
3.2 添加包定义与配置文件
往项目目录下添加下列包定义与配置文件:
- package.json 列出hellworld 程序的依赖,并定义了一些有用的脚本。
{ "name": "version": "1.0.0", "description": "hello "scripts": { "start": "tsc && "lite": "tsc": "tsc", "tsc:w": "tsc -w" }, "license": "ISC", "dependencies": { "@angular/common": "@angular/compiler": "@angular/core": "@angular/forms": "@angular/http": "@angular/platform-browser": "@angular/platform-browser-dynamic": "2.0.0-rc.4", "@angular/router": "systemjs": "core-js": "^2.4.0", "reflect-metadata": "rxjs": "zone.js": "^0.6.12", "bootstrap": "^3.3.6" }, "devDependencies": { "concurrently": "lite-server": "typescript": } } |
- tsconfig.json 是 TypeScript 的编译器配置文件。
{ "compilerOptions": { "target": "es5", "module": "commonjs", "moduleResolution": "sourceMap": true, "emitDecoratorMetadata": true, "experimentalDecorators": true, "removeComments": false, "noImplicitAny": false } } |
- systemjs.config.js 是 SystemJS 的配置文件,本程序采用SystemJS作为模块加载器。
/** * System configuration for Angular 2 samples * Adjust as necessary for your application */ (function (global) { // map tells the System loader where to var map = { 'app': 'app', // 'dist', '@angular': 'node_modules/@angular', 'rxjs': 'node_modules/rxjs' }; // packages tells the System loader how to var packages = { 'app': { main: 'main.js', 'rxjs': { defaultExtension: 'js' } }; var ngPackageNames = [ 'common', 'compiler', 'core', 'forms', 'http', 'platform-browser', 'platform-browser-dynamic', 'router' ]; // Individual files (~300 requests): function packIndex(pkgName) { packages['@angular/' + pkgName] = { main: } // Bundled (~40 requests): function packUmd(pkgName) { packages['@angular/' + pkgName] = { main: } // Most environments should use UMD; some var setPackageConfig = // Add package entries for angular packages ngPackageNames.forEach(setPackageConfig); var config = { map: map, packages: packages }; System.config(config); })(this); |
3.3 安装依赖包
npm install 来安装对应的依赖包
安装完成以后就可以开始写代码了
4. 创建应用文件
在ng2-helloworld 创建一个文件夹 app,在app文件夹下创建文件app.ts如下所示:
import { Component } @Component({ selector: 'app', template:'<h1>hello }) export class } |
AppComponent
是应用的根组件,每个
Angular 应用都至少有一个根组件 ,它是放用户界面的容器。 组件是 Angular 应用程序中最基本的模块,组件通过它所关联的模板,控制视图。
一个组件包括三个基本部分:
l 一个或多个 import 语句来引入所需的文件。
l 一个 @Component 装饰器 来告诉 Angular ,使用哪个模板,以及怎样创建这个组件。
l 一个 组件类 来通过它的模板控制一个视图的外观和行为。
(1). 导入
Angular 应用都是模块化的,它们由很多职责明确的文件组成。 Angular 本身也是模块化的。它包括一系列的库模块,这些模块包括了一系列相关的特性,以便拿来构建应用程序。
当需要一个模块中的某些东西时,引入 (import) 它。 在这里,我们导入了 Angular 2 核心库,以便组件代码访问 @Component 装饰器。
(2). @Component
Component
是一个 装饰器函数
,它接受一个 元数据对象 作为参数。 通过给这个函数加上 @ 前缀,并使用
metadata 对象调用它,能够把 元数据 关联到组件类上。这些元数据会告诉 Angular 如何创建和使用组件类。
这里的这个元数据对象有两个字段:一个 selector ,一个 template 。
selector:指定了一个简单的 CSS 选择器,用于指出放置此组件的 HTML 元素。在此
template:指定了此组件的模板。 它用一种增强的 HTML 形式写成,用来告诉
Angular 如何渲染此组件的视图。模板中只有一行 HTML :“ My First
Angular App ”。模板还可以包含更加复杂的语法,准确来说,一个Angular应用就是一个组件树。
(3). Component
类
文件的最底下,是一个空的,什么也不做的类,叫做 AppComponent 。
打算构建一个真实的应用时,通过添加属性和应用逻辑来扩展这个类。导出 AppComponent,以便在应用的其它地方 导入。
5. 创建启动文件
在app 文件夹创建一个文件 main.ts
,用来启动Angular程序
import { bootstrap } import { AppComponent bootstrap(AppComponent) .then(success => .catch(error => console.log(error)); |
我们引入了两样东西来启动本应用:
- Angular 的浏览器 bootstrap(引导) 函数
- 应用的根组件: AppComponent 。
然后,调用 bootstrap 函数,并且把 AppComponent 传进去。启动函数与应用程序是两个相互分离的关注点。
6. 创建宿主页面
在ng2-helloworld 创建一个文件 index.html 作为Angular程序的宿主页面。
<html> <head> <title>hello world</title> <meta charset="UTF-8"> <meta name="viewport" <!-- 1. Load libraries --> <!-- Polyfill(s) for older browsers <script <script <script <script <!-- 2. Configure SystemJS --> <script <script> System.import('app').catch(function(err){ </script> </head> <!-- 3. Display the application --> <body> <app>Loading...</app> </body> </html> |
这段儿 HTML 值得注意的有:
l 引入JavaScript 库,首先引入 es6-shim ,它会给全局对象 window 打上补丁,使其支持 ES2015(ES6) 的必备特性。然后是 Angular 中使用的zone.js
和 reflect-metadata
,最后是用于模块加载的 SystemJS 库。
l 配置 SystemJS ,以便引入和运行刚才写的 main 文件。
l <body> 中的 <app> 标签是引入根应用程序组件。
7. 构建并运行
打开终端窗口,并输入如下命令:
npm
start
这个命令运行两个并行的 node 进程
TypeScript
编译器,运行在监视
(watch) 模式
一个名叫 lite-server 的静态服务器,它把 index.html
加载到浏览器中
Angular2 入门的更多相关文章
- Angular2入门系列教程7-HTTP(一)-使用Angular2自带的http进行网络请求
上一篇:Angular2入门系列教程6-路由(二)-使用多层级路由并在在路由中传递复杂参数 感觉这篇不是很好写,因为涉及到网络请求,如果采用真实的网络请求,这个例子大家拿到手估计还要自己写一个web ...
- Angular2入门系列教程6-路由(二)-使用多层级路由并在在路由中传递复杂参数
上一篇:Angular2入门系列教程5-路由(一)-使用简单的路由并在在路由中传递参数 之前介绍了简单的路由以及传参,这篇文章我们将要学习复杂一些的路由以及传递其他附加参数.一个好的路由系统可以使我们 ...
- Angular2入门系列教程5-路由(一)-使用简单的路由并在在路由中传递参数
上一篇:Angular2入门系列教程-服务 上一篇文章我们将Angular2的数据服务分离出来,学习了Angular2的依赖注入,这篇文章我们将要学习Angualr2的路由 为了编写样式方便,我们这篇 ...
- Angular2入门系列教程4-服务
上一篇文章 Angular2入门系列教程-多个组件,主从关系 在编程中,我们通常会将数据提供单独分离出来,以免在编写程序的过程中反复复制粘贴数据请求的代码 Angular2中提供了依赖注入的概念,使得 ...
- Angular2入门系列(五)———— 路由参数设置
Angular2入门系列(五)---- 路由参数设置路由配置: { path: '', component: CarProFile, children: [ { path: 'add', compon ...
- Angular2 入门详解
AngularJS 2 快速入门 npm是什么? npm其实是Node.js Package Manager的简称,是Node.js包管理工具(package manager) 安装Node.js ...
- Angular2入门系列教程3-多个组件,主从关系
上一篇 Angular2项目初体验-编写自己的第一个组件 好了,前面简单介绍了Angular2的基本开发,并且写了一个非常简单的组件,这篇文章我们将要学会编写多个组件并且有主从关系 现在,假设我们要做 ...
- Angular2入门系列教程2-项目初体验-编写自己的第一个组件
上一篇 使用Angular-cli搭建Angular2开发环境 Angular2采用组件的编写模式,或者说,Angular2必须使用组件编写,没有组件,你甚至不能将Angular2项目启动起来 紧接着 ...
- Angular2入门系列教程1-使用Angular-cli搭建Angular2开发环境
一直在学Angular2,百忙之中抽点时间来写个简单的教程. 2016年是前端飞速发展的一年,前端越来越形成了(web component)组件化的编程模式:以前Jquery通吃一切的田园时代一去不复 ...
随机推荐
- python基础-装饰器
一.什么是装饰器 装饰器本质就是函数,功能是为其他函数附加功能 二.装饰器遵循的原则 1.不修改被修饰函数的源代码 2.不修改被修饰函数的调用方式 三.实现装饰器的知识储备 装饰器=高阶函数+函数嵌套 ...
- iOS项目常用效果方法注意点集锦
移动中隐藏tabBar,静止显示tabbar - (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView { // 隐藏tabbar ...
- 还原数据库:The backup set holds a backup of a database other than the existing database……
还原数据库时报以上错误,解决办法是: 1.删除新建的DB 2.直接右键Databases-->Restore Database 3.在弹出窗口中的To database栏位填写需要新建的DB名称 ...
- jQuery插件 -- Cookie插件jquery.cookie.js(转)
Cookie是网站设计者放置在客户端的小文本文件.Cookie能为用户提供很多的使得,例如购物网站存储用户曾经浏览过的产品列表,或者门户网站记住用户喜欢选择浏览哪类新闻. 在用户允许的情况下,还可以存 ...
- JAVA_jdk下载和环境变量的配置
Java是一种计算机编程语言,拥有跨平台.面向对象.泛型编程的特性,广泛应用于企业级Web应用开发和移动应用开发. 基本组成: Java由四方面组成:Java编程语言.Java类文件格式.Java虚拟 ...
- Redis java操作客户端
Jedis常用操作 1.测试连通性 Jedis jedis = new Jedis("192.168.1.201",6380,10000); System.out.println( ...
- 正则表达式解析url参数
解析url参数正则:(?<=\?|&)[\w\={}\\\\,-:'\s'""]*(?=[^#\s]|) 意思是(?<=\?|&) 从?或&符号 ...
- 最简单的JavaScript模板引擎
在小公司待久了感觉自己的知识面很小,最近逛博客园和一些技术网站看大家在说JavaScript模版引擎的事儿,完全没有概念,网上一搜这是08年开始流行起来的...本来以为这是很高深的知识,后来在网上看到 ...
- QQ空间爬虫最新分享,一天 400 万条数据(附代码地址)
http://mp.weixin.qq.com/s?__biz=MzAxMjUyNDQ5OA==&mid=2653552228&idx=1&sn=e476bf23556406c ...
- 11月15日下午 ajax返回数据类型为XML数据的处理
ajax返回数据类型为XML数据的处理 /*XML:可扩展标记语言 HTML:超文本标记语言 标签:<标签名></标签名> 特点: 1.必须要有一个根 2.标签名自定义 3.对 ...