1.  

1.指令

  1.  

  *ngIf: 判断 isActive 为true时 <user-detail> 生效展示

  1.   <user-detail *ngIf="isActive"></user-detail>

  *ngFor:遍历显示

    <div *ngFor="let user of users">{{user.fullName}}</div>

  ngClass:class为true类名text-success生效

  1.     [ngClass]="{'text-success':true}"

  ngStyle: 样式绑定

  1.     <div [ngStyle]="{'background-color':'green'}"></<div>
      判断添加
        <div [ngStyle]="{'background-color':username === 'zxc' ? 'green' : 'red' }"></<div>
  1.  

  ngModule: 双向绑定

  1.   <div>
  2.   <h2>{{hero.name}} 信息!</h2>
  3.   <label>name: </label>
  4.   <input [(ngModel)]="hero.name" placeholder="name">
  5.   </div>

以下原文地址:http://victorsavkin.com/post/119943127151/angular-2-template-syntax

2. 属性和事件绑定

属性绑定

假设我们有一个组件来呈现的Todo,我们可以在我们的模板中使用这个组件,如下所示:

  1. <todo-cmp [model]="myTodo"></todo-cmp>

这告诉Angular,只要myTodo发生变化,当有一个新的todo时,Angular会通过模型来自动更新todo组件

事件绑定

现在,让我们添加一个事件使组件更有趣。

  1. <todo-cmp [model]="todo" (complete)="onCompletingTodo(todo)"></todo-cmp>

当事件complete触发时会告诉Angular调用 onCompletingTodo 方法

现在,让我们看看TodoCmp本身。

  1. @Component({
  2. selector: 'todo-cmp',
  3. properties: ['model'],
  4. events: ['complete']
  5. })
  6. class TodoCmp {
  7. model;
  8. complete = new EventEmitter(); // TypeScript 支持初始化
  9. onCompletedButton() {
  10. this.complete.next(); // 触发事件
  11. }
  12. }

这个组件声明数据绑定的名字为model,事件名为complete

Angular使用Rx事件风格来处理事件的接收,EventEmitter即实现了observable,又实现了observer接口(规范),因此,我们可以用它来触发事件,并且Angular也可以用它来监听事件。

正如你所看到的,属性和事件绑定的核心语法很简单。在核心语法之上,Angular提供了一些语法糖,使表达常用的编程模式更加容易。重要的是要了解,这仅仅是语法糖,而且它不会改变语义。

双向绑定

双向数据绑定在某些情况下是很方便的,最值得注意的是处理输入,正如我刚才提到的,属性绑定用于数据从父传递给子,事件绑定用于从子到父的数据传递。因此,我们可以使用两种方法来实现双向绑定。

  1. <input [ng-model]="todo.text" (ng-model)="todo.text=$event"></input>

虽然这可以正常工作,但这太罗嗦。因为这是一个常见的模式,所以Angular提供语法糖简化这种写法。

  1. <input [(ng-model)]="todo.text"></input>

要完成这个例子,让我们来实现Angular 2的ng-model

  1. @Directive({
  2. selector: '[ng-model]',
  3. properties: ['ngModel'],
  4. events: ['ngModelChanged: ngModel'],
  5. host: {
  6. "[value]": 'ngModel',
  7. "(input)": "ngModelChanged.next($event.target.value)"
  8. }
  9. })
  10. class NgModelDirective {
  11. ngModel:any; // stored value
  12. ngModelChanged:EventEmitter; // an event emitter
  13. }

这是一种比较幼稚的ngModel实现,但它说明了如何实现双向数据绑定行为:输入将在text发生更改时更新,并在输入更改时更新text字段。

请注意,于Angular 1相反,你只要看看模板就可以知道哪些绑定是“双向”,哪些是“单向”。

此外,因为只有一个方向,属性绑定,被Angular自动执行,双向的行为更可预测的。

它不会破坏任何Angular 2的语法:这只是一些语法糖,没有别的。

我想提一提,你不用去实现NgModel。Angular 2配备了一个表单处理模块,其包括NgModel的实现。

插值

  1. <div>Hello {{name}}</div>

使用语法糖

  1. <div [textContent]="interpolate(['Hello'], [name])"></div>

绑定直接量

  1. <show-title title="Some Title"></show-title>

使用语法糖

  1. <show-title [title]=" 'Some Title' "></show-title>

移除括号

你可以使用bind-,in-和bindon-在你的模板中代替所有的括号,虽然这几乎不能称为“语法糖”

  1. <some-component [prop]="someExp" (event)="someEvent()" [(two-way-prop)]="someExp"></show-title>

于上面相同

  1. <some-component bind-prop="someExp" on-event="someEvent()" bindon-two-way-prop="someExp"></show-title>

3.局部变量

有两个组件互相交互,这种情况并不少见,Angular 2在模板中支持定义的局部变量。

  1. <video-player #player></video-player>
  2. <button (click)="player.pause()">Pause</button>

#player表示当前video-player组件自身,而没有#player的组件则可以通过player访问video-player组件

  1. <input #i>
  2. {{i.value}}

语法糖

  1. <video-player #player></video-player>

相当于

  1. <video-player var-player></video-player>

模板和 *

Angular以特殊的方式对待template元素。它们用来创建视图,你可以动态操作DOM块,*语法是一种捷径,它可以使你不用写出全部的<template>元素,让我告诉你它是如何工作。

假设我们呈现Todo列表组件。

  1. <todo-cmp *ng-for="#t of todos; #i=index" [model]="t" [index]="t"></todo-cmp>

去除语法糖后变为

  1. <todo-cmp template="ng-for #item of items; #i=index" [model]="t" [index]="i"></todo-cmp>

再一次去除语法糖后变为

  1. <template ng-for #item="$implicit" [ng-for-of]="items" #i="index">
  2. <todo-cmp [model]="t" [index]="t"></todo-cmp>
  3. </template>

该ngFor指令在视图上会创建$implicit和$index变量并绑定到模板上,在模板元素上声明的所有变量只能在元素内提供,这就是为什么以下是不正确

  1. <todo-cmp *ng-for="#t of todos"></todo-cmp>
  2. {{t}} <!-- t cannot be referenced here -->

你需要重点理解的是,当你建立你自己的指令来处理视图时,你的 * syntax 语法能扩展成什么。例如,如果你看ngfor,你会发现它有ngforof属性,但是没有of属性。

为什么不对ng-for自定义语法,象angular 1一样呢?这有几个很好的理由。有自定义语法意味着你必须知道这个微语言如何操作。这也意味着在工具(例如,IDE和LInter)中不能理解你的模板而且并不能提供自动完成和重构。

web组件和原生元素

在这篇博客我谈到了一切的内容 - 局部变量,属性和事件绑定 - 对于web组件和标准的html元素来讲使用方式是完全相同

我可以用Web组件更换TodoCmp,仍然使用相同方式与它进行交互。

  1. <todo-cmp [model]="todo" (completed)="onCompletingTodo(todo)"></todo-cmp>

我可以用Web组件更换视频播放器,仍然使用相同方式与它进行交互。

  1. <video-player #player></video-player>
  2. <button (click)="player.pause()">Pause</button>

这将变得极为重要,因为更多的组件库可用。当运行在非Angular组件上也很重要(这是Angular 2目标之一),否者你不得不把每一个原生组件包装成一个Angular 2组件,那真的很糟糕。Angular 2你可以直接使用任何本地组件,使用相同的语法,只有当你例如想使用依赖注入时,可将它包装为Angular组件

设计目标

我希望你能明白在Angular 2里模板语法是怎么运作的.现在,我想来讨论一下为什么它用这种方式运作?它这么设计的目的是什么?

我们的主要设计目标是使模板更加清晰,开发者在不知如果使用指令情况也能够理解和重构模板,以及指令是如何工作的。

  1. <component [property1]="name" property2="name"></component>

不管组件元素是什么,property1是指向一个name变量的属性 property2属性只表示一个name字符串,你也需要知道,组件的property2属性无法更新,property1属性绑定更新是从父到子。

  1. <component [(property1)]="name"></component>

在这里,我们可以看到,name可以被更新,因为我们使用[()]语法

同样,你可以告诉在模板中定义了哪些变量,来看这里的*nf-for

  1. <todo-cmp *ng-for="#t of todos"></todo-cmp>

其次,我们希望有丰富的开发工具,在下面的列子中,工具可以静态地推断出第一个index是组件上的字段,而第2个index是ng-for输出的局部变量

  1. {{index}}
  2. <div *ng-for="#item of items; var index=index">
  3. {{index}
  4. </div>

angular2.x指令的更多相关文章

  1. angular2 通过指令限制输入

    最近在写一个表单,有些输入框只能输入数字,单又不想每次写表单的时候,都要去验证输入的是不是数字, 那么就想到直接限制只能输入数字,通过指令实现 这里需要注意的是,不只更改DOM的值,如果input为数 ...

  2. ionic2 angular2 模板指令补充

    向div中插入带有html标签的数据   [innerHTML]="item.content"    字符串截取指令                       {{item.de ...

  3. Angular2 从0到1 (二)

    第一节:Angular2 从0到1 (一)第三节:Angular2 从0到1 (三)第四节:Angular2 从0到1 (四) 作者:王芃 wpcfan@gmail.com 第二节:用Form表单做一 ...

  4. angular2项目关于Echarts图表的处理

    在NiceFish项目中关于Echarts组件和指令是直接注册在appModule根模块中的,这样路由只需这样写就可以让浏览器加载图标组件: 在chart组件视图中: <div class=&q ...

  5. 利用Angular2的Observables实现交互控制

    在Angular1.x中,我们使用Promise来处理各种异步.但是在angular2中,使用的是Reactive Extensions (Rx)的Observable.对于Promise和Obser ...

  6. 迈向angularjs2系列(4):脏值检测机制

    目录 一: 概念简介 脏值检测,简单的说就是在MVC的构架中,视图会通过模型的change事件来更新自己. 脏值检测的核心代码是观察者模式的实现,其机制会执行digest循环,在特定UI组件的上下文执 ...

  7. Angular2 指令

      1. 指令说明 Angular2 指令是构成Angular2应用程序的重要组成部分,指令主要用来对模板的标签或者元素附加一些新的特性或者功能,改变一个 DOM 元素的外观或行为,Angular2指 ...

  8. Angular2组件与指令的小实践——实现一个图片轮播组件

    如果说模块系统是Angular2的灵魂,那其组件体系就是其躯体,在模块的支持下渲染出所有用户直接看得见的东西,一个项目最表层的东西就是组件呈现的视图.而除了直接看的见的躯体之外,一个完整的" ...

  9. 迈向angularjs2系列(2):angular2指令详解

    一:angular2 helloworld! 为了简单快速的运行一个ng2的app,那么通过script引入预先编译好的angular2版本和页面的基本框架. index.html: <!DOC ...

随机推荐

  1. break和continue 的区别

    区别 break和continue都可在循环语句里面使用,也都可以控制外层的循环.但是continue只能在循环语句里面使用,break也可以使用在switch语句里面. break具体作用在循环语句 ...

  2. 【学习】ie-css3.htc---让ie8以下支持css3

    学习了偶象大神的一篇文章:<让IE6/IE7/IE8浏览器支持CSS3属性>http://www.zhangxinxu.com/wordpress/?p=783 亲自实践了一下,主要是bo ...

  3. YYHS-NOIP模拟赛-mine

    题解 这道题不难想到用dp来做 dp[i][0]表示第i个格子放0 dp[i][1]表示第i个格子放1且第i-1个格子放雷 dp[i][2]表示第i个格子放2 dp[i][3]表示第i个格子放1且第i ...

  4. Pyquery API中文版

    Pyquery的用法与jQuery相同,可以直接参考jQuery API学习.

  5. 简述Apache的ab测试主要有那些关键指标

    一.ab的原理 ab是apachebench命令的缩写. ab的原理:ab命令会创建多个并发访问线程,模拟多个访问者同时对某一URL地址进行访问.它的测试目标是基于URL的,因此,它既可以用来测试ap ...

  6. ELK系列~NLog.Targets.Fluentd到达如何通过tcp发到fluentd

    最近火的不能再火的日志框架就是ELK,其中E(Elasticsearch)表示日志存储,L(Logstash)表示日志收集,K(kibana)表示日志的UI界面,用来查询和分析,而其中的L可以使用Fl ...

  7. MyBatis 笔记总结

    1.MyBatis中的一些要点: 1.1 SqlMapConfig.xml:mybatis的全局配置文件,配置mybatis的运行环境等信息,包括mapper.xml文件 1.2 mapper.xml ...

  8. css3中“渐变”兼容性解决方案

    这次是简单的谈一下我们常见的渐变在各个浏览器下的兼容性问题,算一个比较简单的问题. 我们熟知的浏览器有Chrome.Firefox.Opera.Safari以及ie系列.最基础的background: ...

  9. LeetCode 27. Remove Element (移除元素)

    Given an array and a value, remove all instances of that value in place and return the new length. D ...

  10. 读书笔记-你不知道的JS上-声明提升

    变量声明提升 Javascript代码一般情况下是由上往下执行的,但是有些情况下不成立. a = 2; //变量声明被提升在当前作用域顶部 var a; console.log(a); console ...