Angular内置指令--通用指令

Angular2的内置指令可分为通用指令、路由指令、表单指令。

通用指令包含7种,均包含在CommonModule模块中,CommonModule已经包含在了BrowserModule中。

  • NgClass
  • Ngstyle
  • NgIf
  • NgFor
  • NgSwitch、NgSwitchCase、NgSwitchDefault
  • NgTemplateOutlet(不常用)
  • NgPlural、NgPluralCase(不常用)

NgClass(属性型指令) : 绑定一个格式为{ CSS类名:boolean } 的对象,true时添加CSS类到模板元素中,反之移除。

//组件模板中
<div [ngClass]="classes">

//组件类中
classes = { highLight: true };

//组件样式中
.highLight {
  background: yellow;
}

 

NgStyle(属性型指令) : 绑定一个格式为{ 'CSS样式名' : '样式值' } 的对象

//组件模板中
<div [ngClass]="classes">

//组件类中
classes = { 'color': 'red' };     //可以用表达式

 

NgIf(结构型指令) : 绑定一个布尔类型的表达式,当表达式返回true时,在DOM树节点上添加一个元素及其子元素,反之移除。

<div *ngIf="方法或表达式">.....<div>

 

NgFor(结构型指令) : 可以实现重复执行某些步骤来展示数据,同时该指令支持一个可选的index索引,在循环迭代过程中,下标范围是 0<=index<数组长度 。

可以使用可选追踪函数NgForTrackBy,下面例子中追踪函数可以让Angular将具有相同id的对象处理成同一个对象,如果检查处同一个对象的属性发生的变化,Angular就会更新DOM元素,反之保留。

<div *ngFor="let value of values; let i=index; trackBy: trackByValues">{{value}}{{i}}<div>
//注意trackByValues不要加()

//组件类
trackByValues(index: number, value: Value) {
  return value.name;
}

 

NgSwitch、NgSwitchCase、NgSwitchDefault : 根据NgSwitch绑定的条件值来进行相关匹配,条件匹配元素保留,不匹配元素则移出模板,没有匹配项会保留NgSwitchDefault项。

<div [ngSwitch]="条件">
  <div *ngSwitchCase="case1">...</div>
  <div *ngSwitchCase="case2">...</div>
  <div *ngSwitchDefault>...</div>
</div>

 

NgTemplateOutlet : 以后再补上...

转载于:https://my.oschina.net/u/3412211/blog/896021

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值