Angular 2 学习笔记(一)

Angular 2 学习笔记(一)

First Application

  • 建立自定义组件(Components)
  • 从表单(Form)接受用户输入(input)
  • 渲染对象列表并用视图战事
  • 监听(Intercepting)用户点击事件并执行操作

Getting started

TypeScript

建议使用 TypeScript 开始 Angular 2 的编程。 Angular 2 有 ES5 API ,但是 Angular 2 是用 TypeScript 写的并且大部分人都在使用 TypeScript 。使用 TypeScript 编写 Angular 2 会更美观和简便。

// 安装 nodejs
// 安装 TypeScript
$ npm install typescript -g

// Windows 用户建议安装 Cygwin

Angular‘s Dependencies

Angular 2 本身就是一个 javascript 文件,并且需要很多依赖来运行它。为了使用 Angular 2 ,你并不需要完全深入地理解每一个依赖,但是你必须引入它们。
Angular 2 主要依赖一下4个库:

  • es6-shim-(for older browsers)
  • angular2-polyfills
  • SystemJS
  • RxJS
<script src="node_modules/es6-shim/es6-shim.js></script>
<script src="node_modules/angular2/bundles/angular2-polyfills.js></script>
<script src="node_modules/systemjs/dist/system.src.js></script>
<script src="node_modules/rxjs/bundles/Rx.js></script>
<script src="node_modules/angular2/bundles/angular2.dev.js></script>

# ES6 Shim

# Angular 2 Polyfills

# SystemJS

# RxJS

First Project

建立 app.ts 。然后浏览器并不知道该如何运行 .ts 文件,所以我们需要将 .ts 文件编译成 .js 文件。

///<reference path="node_modules/angular2/ts/typings/node/node.d.ts"/>
///<reference path="node_modules/angular2/typings/browser.d.ts"/>
import { bootstrap } from "angular2/platform/browser";
import { Component } from "angular2/core";

@Component({
    selector: ‘hello-world‘,
    template: `
        <div>
            Hello World
        </div>
    `
})
class HelloWorld {
}

bootstrap(HelloWorld);

TypeScript 是 javascript 的一种类型。为了能够在我们的浏览器中使用Angular ,我们需要告诉 TypeScript 编译器需要从哪里找 typing files 。 reference 标签里面声明了 typing files 的路径(以 .d.ts 结尾)。

import 标签定义了我们在我们的代码中所使用到的模块(modules)。这里我们引入了两个模块: Component 和 bootstrap 。

我们从 "angular2/core" 引入 Conponent 。"angular2/core" 模块告诉程序需要的依赖的所在地。同样我们从 "angular2/platform/browser" 引入 bootstrap 。

注意 import 语法的结构是 import { things } from wherever

Making a Component

Angular 2 的核心概念之一就是组件(Components)。

在 Angular 应用中我们使用 HTML 标记语言来构建应用的交互,但是浏览器只识别一些标签,比如像 <select><form><video> 这些由浏览器创建者定义的功能性标签。但是万一我们想要教给浏览器一些新的标签呢?万一我们想要有一个名叫 <weather> 的标签去显示天气呢?或者我们需要一个 <login> 标签来创建登陆面板呢?

这就是组件(Components)背后的理念:我们教给浏览器使用具有新功能的新标签。

我们创建的第一个组件,当我们在 HTML 文档中使用我们的组件的时候:

<hello-world></hello-world>

所以我们事实上是如何定义一个新组件的呢?一个基本的组件包括两部分:

  1. A Component annotation
  2. A compontent definition class

Adding a template

Booting Our Application

bootstrap(HelloWorld); 将会启动应用。第一点隐藏的含义是:我们的应用的 main 组件是 HelloWorld 组件。

一旦应用被加载(bootstrapped), 在 index.html 文件里的 <hello-world></hello-world> 片段将由 HelloWorld 组件渲染。

Loading our Application

要运行我们的应用,我们需要做两件事:

  1. we need to tell our HTML document to import our app file
  2. we need to use our component

<body> 中添加:

<script>
    System.config({
        packages: {
            app: {
                format: ‘register‘,
                defaultExtension: ‘js‘
                }
            }
        });
    System.import(‘app.js‘)
        .then(null,
            console.error.bind(console));
</script>
<hello-world></hello-world>

Running The App

Compiling the TypeScript Code to .js

Serving The App

Adding Data to the Component

未完待续...

时间: 2024-11-06 19:08:00

Angular 2 学习笔记(一)的相关文章

[Pro Angular.JS]学习笔记1.1:设置开发环境

可以使用yeoman.io,很方便.我已经写了一篇随笔,介绍如何使用.这里也有一篇介绍的文章:http://www.cnblogs.com/JoannaQ/p/3756281.html 代码编辑器,在Mac下用了一下WebStorm,太恶心了.另外发现书的作者使用的开发环境是Windows + VS Express 2013,为了方便学习,我也使用VS Express 2013 Update2.VS2013用起来蛮舒服的,把WebStorm比得跟驼屎一样.也许是因为我没用习惯吧. 1.安装Nod

Angular JS 学习笔记

特定领域语言 编译器:遍历DOM来查找和它相关的属性, 分为编译和链接两个阶段, 指令:当关联的HTML结构进入编译阶段时应该执行的操作,可以写在名称里,属性里,css类名里:本质上是函数 稳定的DOM:绑定了数据模型的DOM元素的实例不会在绑定的生命周期发生改变 作用域:用来检测模型的改变和为表达式提供执行上下文的 AngularJS 和其它模板系统不同,它使用的是DOM而不是字符串 指令: 由某个属性.元素名称.css类名出现而导致的行为,或者说是DOM的变化 Filter过滤器:扮演着数据

Angular【学习笔记】

1.angular入门网站 感谢@菜鸟教程:http://www.runoob.com/angularjs/angularjs-tutorial.html 学习笔记:

Angular JS学习笔记

之前的学习方法有点盲目,建议以后只看与工作有关的内容,并且多问那些是只和工作有关联的. 遇到问题的时候,项目不急的话,自己研究,项目急的话,马上问. 方法不对,再努力也没有用. Angular JS学习网站:http://www.zouyesheng.com/angular.html#toc7 [  项目有关的内容 ] ng-model ng-click ng-options ng-repeat ng-if ng-show ng-hide ng-controller ng-href(有印象) {

[Cousera Angular JS学习笔记]第一周

最近在给搜索引擎做前台,开始学习Angular JS,直接上coursera上的课程:https://www.coursera.org/learn/angular-js/home/week/1(没有JS基础的同学可以和我一样先过下cousera的JS课程 Interacticity with JavaScript) 要先安装bower(方便获取JS),安装bower之前要先安装node JS (1) 安装nodejs过程直接参考http://czpae86.iteye.com/blog/1636

angular.js学习笔记--概念总结

好久没更新了,现在开始学习学习angularjs,并且把学习到的一些知识总结记录一下,方便以后查找以及希望能给初学者一些帮助!(由于本人也是初学ng所以各位慎重理解!) 废话不多说,开始! $rootScope 和 $scope: $rootScope是angular中最接近全局作用域的对象,是所有$scope对象的最上层! $scope对象就是一个普通的js对象,我们可以在其上随意修改和添加属性,并且其在angular中充当数据模型,它是所有属性都可以自动呗视图访问到,但是它并不负责数据的处理

[Cousera Angular JS学习笔记]第一周(2)

之前写了一个简单的angular的页面,这边主要要学习几个用法:controller,filter (1)第一个练习主要是把原来的ng-init的内容移到controller 首先定义module名称 <html lang="en" ng-app="confusionApp"> 然后初始化module和controller,是在script标签下面 <script> var app = angular.module('confusionApp

Angular JS 学习笔记(一)

1. 菜鸟教程:http://www.runoob.com/angularjs/angularjs-tutorial.html 2. Angular JS中文网:http://www.apjs.net/

Angular.js学习笔记 (二)

用A链接对象解析url的组成 var url = 'https://www.baidu.com:8080/aaa/1.html?id=10#name'; var aLink = document.createElement('a'); aLink.href = url; console.log(aLink);//<a href="https://www.baidu.com:8080/aaa/1.html?id=10#name"></a> console.log(