这篇文章基本明白怎么渲染模板,但是我的工程会报错说#号非法,这篇的写法也不好用。

angular2.0.0的语法集

Angular for TypeScript 语法快速指南 (基于2.0.0版本)

引导

import { platformBrowserDynamic } from '@angular/platform-browser-dynamic';

platformBrowserDynamic().bootstrapModule(AppModule);

使用JIT编译器引导一个AppModule模块定义的应用

NgModules

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

@NgModule({ declarations: ..., imports: ...,
     exports: ..., providers: ..., bootstrap: ...})
class MyModule {}

定义一个模块,其中包括组件、指令、管道和提供商。

declarations: [MyRedComponent, MyBlueComponent, MyDatePipe]

一个数组,包括从属于当前模块的组件、指令和管道。

imports: [BrowserModule, SomeOtherModule]

一个数组,包括被导入到当前模块中的所有模块。来自被导入模块的declarations也同样对当前模块有效。

exports: [MyRedComponent, MyDatePipe]

一个数组,包括对导入当前模块的模块可见的组件、指令、管道。

providers: [MyService, { provide: ... }]

一个数组,包括在对前模块及导入当前模块的模块中的内容物(组件、指令、管道、提供商等)可见的依赖注入提供商。

bootstrap: [MyAppComponent]

一个数组,包括由当前模块引导时应该引导的组件

模板语法  
<input [value]="firstName">

把属性value绑定到表达式firstName的结果。

<div [attr.role]="myAriaRole">

role这个Attribute绑定到表达式 myAriaRole的结果。

<div [class.extra-sparkle]="isDelightful">

把元素是否出现CSS类extra-sparkle,绑定到一个表达式isDelightful的结果是否为真。

<div [style.width.px]="mySize">

把样式的width属性绑定到表达式mySize的结果,以px为单位。这个单位是可选的。

<button (click)="readRainbow($event)">

当按钮(及其子元素)上的click事件被触发时,调用readRainbow方法,并把事件对象作为参数传入。

<div title="Hello {{ponyName}}">

把属性绑定到一个插值表达式字符串,比如 "Hello Seabiscuit"。它等价于: <div [title]="'Hello ' + ponyName">

<p>Hello {{ponyName}}</p>

把文本内容绑定到一个插值表达式,比如 "Hello Seabiscuit".

<my-cmp [(title)]="name">

设置双向数据绑定。等价于:<my-cmp [title]="name" (titleChange)="name=$event">

<video #movieplayer ...>
  <button (click)="movieplayer.play()">
</video>

创建一个局部变量 movieplayer ,它提供到video元素实例的访问,可用于当前模板中的数据绑定和事件绑定表达式中。

<p *myUnless="myExpression">...</p>

*符号表示当前元素将被转变成一个内嵌模板。等价于: <template [myUnless]="myExpression"><p>...</p></template>

<p>Card No.: {{cardNumber | myCardNumberFormatter}}</p>

通过名叫myCardNumberFormatter的管道,转换表达式的当前值cardNumber

<p>Employer: {{employer?.companyName}}</p>

安全导航运算符(?.)表示employer字段是可选的,如果它是undefined,表达式剩下的部分将被忽略

<svg:rect x="0" y="0" width="100" height="100"/>

SVG模板需要在它们的根节点上带一个svg:前缀,以消除模板中HTML元素和SVG元素的歧义。

<svg>
  <rect x="0" y="0" width="100" height="100"/>
</svg>

<svg>元素在无需前缀的情况下,也能被自动检测为SVG。

内置指令

import { CommonModule } from '@angular/common';

<section *ngIf="showSection">

基于showSection表达式的值移除或重新创建部分DOM树。

<li *ngFor="let item of list">

把li元素及其内容转化成一个模板,并用它来为列表中的每个条目初始化视图。

<div [ngSwitch]="conditionExpression">
  <template [ngSwitchCase]="case1Exp">...</template>
  <template ngSwitchCase="case2LiteralString">...</template>
  <template ngSwitchDefault>...</template>
</div>

基于conditionExpression的当前值,从内嵌模板中选取一个,有条件的切换div的内容。

<div [ngClass]="{active: isActive, disabled: isDisabled}">

把一个元素上CSS类的出现与否,绑定到一个真值映射表上。右侧的表达式应该返回类似{class-name: true/false}的映射表。

表单

import { FormsModule } from '@angular/forms';

<input [(ngModel)]="userName">

提供双向绑定,为表单控件提供解析和验证。

类装饰器

import { Directive, ... } from '@angular/core';

@Component({...})
class MyComponent() {}

声明当前类是一个组件,并提供关于该组件的元数据。

@Directive({...})
class MyDirective() {}

声明当前类是一个指令,并提供关于该指令的元数据。

@Pipe({...})
class MyPipe() {}

声明当前类是一个管道,并且提供关于该管道的元数据。

@Injectable()
class MyService() {}

声明当前类有一些依赖,当依赖注入器创建该类的实例时,这些依赖应该被注入到构造函数中。

指令配置

@Directive({ property1: value1, ... })

selector: '.cool-button:not(a)'

指定一个CSS选择器,以便在模板中找出该指令。支持的选择器包括element[attribute].class, 和 :not()

不支持父子关系选择器。

providers: [MyService, { provide: ... }]

为当前指令及其子指令提供依赖注入的providers数组。

组件配置

@Component扩展了@Directive, 以便@Directive中的配置项也能用在组件上

moduleId: module.id

如果设置了,templateUrlstyleUrl会被解析成相对于组件的。

viewProviders: [MyService, { provide: ... }]

依赖注入provider的数组,局限于当前组件的视图中。

template: 'Hello {{name}}'
templateUrl: 'my-component.html'

当前组件视图的内联模板或外部模板地址

styles: ['.primary {color: red}']
styleUrls: ['my-component.css']

内联CSS样式或外部样式表URL的列表,用于给组件的视图添加样式。

供指令类或组件类用的字段装饰器。

import { Input, ... } from '@angular/core';

@Input() myProperty;

声明一个输入属性,以便我们可以通过属性绑定更新它。(比如:<my-cmp [my-property]="someExpression">).

@Output() myEvent = new EventEmitter();

声明一个输出属性,以便我们可以通过事件绑定进行订阅。(比如:<my-cmp (my-event)="doSomething()">).

@HostBinding('[class.valid]') isValid;

把宿主元素的属性(比如CSS类:valid)绑定到指令/组件的属性(比如:isValid)。

@HostListener('click', ['$event']) onClick(e) {...}

通过指令/组件的方法(例如onClick)订阅宿主元素的事件(例如click),可选传入一个参数($event)。

@ContentChild(myPredicate) myChildComponent;

把组件内容查询(myPredicate)的第一个结果绑定到类的myChildComponent属性。

@ContentChildren(myPredicate) myChildComponents;

把组件内容查询(myPredicate)的全部结果,绑定到类的myChildComponents属性。

@ViewChild(myPredicate) myChildComponent;

把组件视图查询(myPredicate)的第一个结果绑定到类的myChildComponent属性。对指令无效。

@ViewChildren(myPredicate) myChildComponents;

把组件视图查询(myPredicate)的全部结果绑定到类的myChildComponents属性。对指令无效。

指令和组件的变更检测与生命周期钩子

(作为类方法实现)

constructor(myService: MyService, ...) { ... }

类的构造函数会在所有其它生命周期钩子之前调用。使用它来注入依赖,但是要避免用它做较重的工作。

ngOnChanges(changeRecord) { ... }

在输入属性每次变化了之后、开始处理内容或子视图之前被调用。

ngOnInit() { ... }

在执行构造函数、初始化输入属性、第一次调用完ngOnChanges之后调用。

ngDoCheck() { ... }

每当检查组件或指令的输入属性是否变化时调用。通过它,可以用自定义的检查方式来扩展变更检测逻辑。

ngAfterContentInit() { ... }

当组件或指令的内容已经初始化、ngOnInit完成之后调用。

ngAfterContentChecked() { ... }

在每次检查完组件或指令的内容之后调用。

ngAfterViewInit() { ... }

当组件的视图已经初始化完毕,每次ngAfterContentInit之后被调用。只适用于组件。

ngAfterViewChecked() { ... }

每次检查完组件的视图之后调用。只适用于组件。

ngOnDestroy() { ... }

在所属实例被销毁前,只调用一次。

依赖注入配置  
provide: MyService, useClass: MyMockService }

把MyService类的提供商设置或改写为MyMockService。

provide: MyService, useFactory: myFactory }

把MyService的提供商设置或改写为myFactory工厂函数。

provide: MyValue, useValue: 41 }

把MyValue的提供商设置或改写为值41。

路由与导航

import { Routes, RouterModule, ... } from '@angular/router';

const routes: Routes = [
  { path: '', component: HomeComponent },
  { path: 'path/:routeParam', component: MyComponent },
  { path: 'staticPath', component: ... },
  { path: '**', component: ... },
  { path: 'oldPath', redirectTo: '/staticPath' },
  { path: ..., component: ..., data: { message: 'Custom' } }
]);

const routing = RouterModule.forRoot(routes);

为应用配置路由。支持静态、参数化、重定向和通配符路由。还支持自定义路由数据和解析。


<router-outlet></router-outlet>
<router-outlet name="aux"></router-outlet>

标记一个位置,用于加载当前激活路由的组件。


<a routerLink="/path">
<a [routerLink]="[ '/path', routeParam ]">
<a [routerLink]="[ '/path', { matrixParam: 'value' } ]">
<a [routerLink]="[ '/path' ]" [queryParams]="{ page: 1 }">
<a [routerLink]="[ '/path' ]" fragment="anchor">

基于路由指令创建指向不同视图的链接,由路由路径、必选参数、可选参数、查询参数和片段(fragment)组成。添加“/”前缀可以导航到根路由。添加“./”前缀可以导航到子路由。添加“../sibling”前缀可以导航到兄弟路由或父路由。

<a [routerLink]="[ '/path' ]" routerLinkActive="active">

routerLink被激活时,就把指定的CSS类添加到该元素上。

class CanActivateGuard implements CanActivate {
    canActivate(
      route: ActivatedRouteSnapshot,
      state: RouterStateSnapshot
    ): Observable<boolean>|Promise<boolean>|boolean { ... }
}

{ path: ..., canActivate: [CanActivateGuard] }

一个用来定义类的接口,路由器会首先调用它来决定是否应该激活该组件。应该返回布尔值或能解析为布尔值的可观察对象(Observable)或承诺(Promise)。

class CanDeactivateGuard implements CanDeactivate<T> {
    canDeactivate(
      component: T,
      route: ActivatedRouteSnapshot,
      state: RouterStateSnapshot
    ): Observable<boolean>|Promise<boolean>|boolean { ... }
}

{ path: ..., canDeactivate: [CanDeactivateGuard] }

一个用来定义类的接口,路由器在导航后会首先调用它来决定是否应该取消该组件的激活状态。应该返回布尔值或能解析为布尔值的可观察对象(Observable)或承诺(Promise)。

class CanActivateChildGuard implements CanActivateChild {
    canActivateChild(
      route: ActivatedRouteSnapshot,
      state: RouterStateSnapshot
    ): Observable<boolean>|Promise<boolean>|boolean { ... }
}

{ path: ..., canActivateChild: [CanActivateGuard],
    children: ... }

一个用来定义类的接口,路由器会首先调用它来决定是否应该激活该子路由。应该返回布尔值或能解析为布尔值的可观察对象(Observable)或承诺(Promise)。

class ResolveGuard implements Resolve<T> {
    resolve(
      route: ActivatedRouteSnapshot,
      state: RouterStateSnapshot
    ): Observable<any>|Promise<any>|any { ... }
}

{ path: ..., resolve: [ResolveGuard] }

一个用来定义类的接口,路由器会在渲染该路由之前先调用它来解析路由数据。应该返回一个值或能解析为值的可观察对象(Observable)或承诺(Promise)。

class CanLoadGuard implements CanLoad {
    canLoad(
      route: Route
    ): Observable<boolean>|Promise<boolean>|boolean { ... }
}

{ path: ..., canLoad: [CanLoadGuard], loadChildren: ... }

一个用来定义类的接口,路由器会首先调用它来决定一个惰性加载的模块是否应该被加载。应该返回布尔值或能解析为布尔值的可观察对象(Observable)或承诺(

然后做了个练习:

如果照某些例子 import {Component,OnInit, NgFor, NgIf} from "@angular/core";//会报错

(1,27): error TS2305: Module '"F:/work/vs1/node_modules/@angular/core/index"' has no exported member 'NgFor'.
...

[0] (1,34): error TS2305: Module '"F:/work/vs1/node_modules/@angular/core/index"' has no exported member 'NgIf'.
[0] Child html-webpack-plugin for "index.html":

export class AmwayComponent implements OnInit{
errorMessage:string;
amwayData:any; constructor(private _globalService: GLobalService,private _uIHelperService:UIHelperService) {} ngOnInit() {
let requestParams = new URLSearchParams();
requestParams.set('id', '');
this._globalService.ajaxCallerGet(this._globalService.getServiceURL('amway'), requestParams).subscribe(
(data) => {
this.amwayData=data;
console.log("amway page data:::"+ data,this.amwayData);
},
error => this.errorMessage = <any>error
);
}
}

NgFor 和 NgIf 现在在Component里,不需要单独提出来导入, OnInit是用来导入data的方法。

export const htmlTemplate = `
<div id = "amway">
<img class="logo" src="{{amwayData?.logo}}">
<div class="slogan">
<p *ngFor="let slogan of amwayData?.slogans">{{slogan}}</p>
</div>
<div class="nav">
<a *ngFor="let nav of amwayData?.navs">
{{nav.name}}
</a>
</div>
<div class="inner_content">
<div class="left">
<ul>
<li class="title">{{amwayData?.left.title}}</li>
<li *ngFor="let list of amwayData?.left.lists">
<p class="name">{{list.name}}</p>
<div class="subs" *ngIf="list.subs">
<p class="sub" *ngFor="let sub of list.subs">
{{sub}}
</p>
</div>
</li>
</ul>
</div>
<div class="right">
<p class="crumbs">
<span *ngFor="let crumb of amwayData?.right.crumbs">{{crumb}}</span>
<p>
<div class="inner_right">
<p class="table_top">
{{amwayData?.right.table_top}}
<p>
<p class="table_info"></p>
</div>
</div>
</div>
</div>
`;

data是这样的:

{
"logo": "assets/images/logo.png",
"slogans": ["您好,","某某"],
"top": ["我的賬戶", "快速選購", "購物籃", "中心", "登出", "English"],
"navs": [{ "name": "紐崔萊" }, { "name": "雅姿" }, { "name": "個人護理" },
{ "name": "家居護理" }, { "name": "家居科技" }, { "name": "其他產品" }, { "name": "優惠" },
{ "name": "產品配件" }, { "name": "XS" }],
"left": { "title": "業績報告", "lists": [{ "name": "積分查詢", "subs": ["個人", "組內"] },
{ "name": "推薦先機獎金報告下載" }, { "name": "未送貨訂單資料壹組" }, { "name": "電子購貨單" },
{ "name": "組內尚未使用指優惠券記錄" }, { "name": "個人業績記錄" }, { "name": "推薦記錄" },
{ "name": "個人獎勵記錄" }, { "name": "直銷商/優惠顧客狀況查詢" }, { "name": "個人及組員資料查詢" },
{ "name": "個人優惠券" }, { "name": "個人訂單" }, { "name": "業務拓展非/電子 優惠 - - 概覽" },
{ "name": "業務拓展非/電子 優惠 - - 直系小組縱覽" }] },
"right": {
"crumbs": ["首頁 > ", "業務資訊 > ", "業績報告 > ", "積分查詢 > ", "組內"],
"table_top":"组内",
"search": ["搜尋直銷商", "優惠顧客編號", "搜尋"],
"table": ["本月積分記錄", "獎金月份", "更新日期", "積分查詢", "直銷商/優惠顧客編號",
          "直銷商/優惠顧客姓名", "戶籍類別", "組內積分額", "加入日期", "轉型日期"]
}
}

从ng-repeat到NgFor的更多相关文章

  1. Part 6 AngularJS ng repeat directive

    ng-repeat is similar to foreach loop in C#. Let us understand this with an example. Here is what we ...

  2. table sorting–angularjs

    1: <script type="text/javascript" ng:autobind 2: src="http://code.angularjs.org/0. ...

  3. [译]用AngularJS构建大型ASP.NET单页应用(三)

    原文地址:http://www.codeproject.com/Articles/808213/Developing-a-Large-Scale-Application-with-a-Single A ...

  4. 初步认识Angulajs

     Angulajs是一个MVC前段框架,项目中使用Angulajs必须按照框架的写法编写代码,可以统一代码规范易于后期代码的维护. M Model 模型-数据,V View 视图-表现层 HTML/C ...

  5. Pytorch版本yolov3源码阅读

    目录 Pytorch版本yolov3源码阅读 1. 阅读test.py 1.1 参数解读 1.2 data文件解析 1.3 cfg文件解析 1.4 根据cfg文件创建模块 1.5 YOLOLayer ...

  6. [Angular 2] Using ng-for to repeat template elements

    This lesson covers Angular 2’s version of looping through data in your templates: ng-for. It’s conce ...

  7. Angular4 Ng 模块

    原文地址 http://www.jianshu.com/p/317f0e4b7284 根模块 (root module) 每个应用都至少有一个根模块用来引导并运行应用.根模块通常命名为 AppModu ...

  8. (原创)Stanford Machine Learning (by Andrew NG) --- (week 8) Clustering & Dimensionality Reduction

    本周主要介绍了聚类算法和特征降维方法,聚类算法包括K-means的相关概念.优化目标.聚类中心等内容:特征降维包括降维的缘由.算法描述.压缩重建等内容.coursera上面Andrew NG的Mach ...

  9. (原创)Stanford Machine Learning (by Andrew NG) --- (week 3) Logistic Regression & Regularization

    coursera上面Andrew NG的Machine learning课程地址为:https://www.coursera.org/course/ml 我曾经使用Logistic Regressio ...

  10. [C2P2] Andrew Ng - Machine Learning

    ##Linear Regression with One Variable Linear regression predicts a real-valued output based on an in ...

随机推荐

  1. 类名.class与类名.this详解

    类名.class      我们知道在java中,一个类在被加载的时候虚拟机就会自动的生成一个这个类的一个Class类型的“类对象”,每个类都对应着一个这样的类对象,通过这个Class类型的类对象,我 ...

  2. Beyond Compare 相同文件对比结果仍显示红色 解决方案

    转载:http://blog.sina.com.cn/s/blog_4d4bc1110100zj7x.html   1. 问题详细描述如下. 下图显示对比结果中,两侧的aaa.xml是一模一样,会话中 ...

  3. 用Java socket (TCP通信模型)实现一个简单的web 服务器

    package cn.magicdu.think.socket; import java.io.OutputStream; import java.io.PrintWriter; import jav ...

  4. glassfish 日志输出配置

    asadmin set-log-levels javax.enterprise.system.tools.deployment=WARNING

  5. 一个layer可以跟着画完的线移动ios程序 好玩啊。

    用法:采用的是关键帧实现的. 实验目的:让上层的layer子层能够跟着在另一个子层上花的线进行移动 .即当线画完之后,图形开始移动,并且能够停在最后的那个位置 效果图: 采用是直接在layer图层上进 ...

  6. (转)unity开发相关环境(vs、MonoDevelop)windows平台编码问题

    转自: http://www.cnblogs.com/sevenyuan/archive/2012/12/06/2805114.html 1.unity会爆出错误: There are inconsi ...

  7. 如何一行jquery代码写出tab标签页(链式操作)

    啦啦!今天又学了一招,js写几十行的tab标签页jquery写一行就行啦,用到了链式操作!以下是代码: <!DOCTYPE html> <html lang="en&quo ...

  8. java集合 collection-list-LinkedList

    import java.util.*; /* LinkedList:特有方法: addFirst(); addLast(); getFirst(); getLast(); 获取元素,但不删除元素.如果 ...

  9. css 控制滚动样式

    ::-webkit-scrollbar{width: 8px; height: 8px;}::-webkit-scrollbar-button:vertical{display:none;}::-we ...

  10. JS中undefined和null的区别

    在写JS脚本的时候,经常会碰到“为空”的判断,其中主要有null和undefined的判断.这两个为空判断的主要区别是: 1) null是JS的关键字,是语法特性.undefined是全局对象的属性, ...