Angular2中的ng-class

时间:2015-05-17 05:44:37

标签: typescript angular typescript1.5

我正在开发一个角度为2的测试应用程序,并且我遇到了根据模型列表添加类的问题。

在Angular 1中,可以做到:

// model
$scope.myClasses = ['class1', 'class2', ...];

// view
... ng-class="myClasses" ...

在Angular 2中,我迄今为止所做的就是:

// view
... [class.class1]="true" [class.class2]="true" ...

这显然不是很有活力,我确信必须有更好的方法来做到这一点。

但是,我也尝试过:

// model
class ... {
    private myClasses: any;
    constructor() {
        this.myClasses = ['class1', 'class2', ...];
    }

// view
... [class]="myClasses" ...

但这不起作用,我尝试myClasses作为单个类的字符串名称,字符串数组,带有类名键的对象和值为true的true,此对象的数组善良,但可悲的是,列出的任何内容都不会这样。

4 个答案:

答案 0 :(得分:39)

根据NgClass API docs,Angular 2将接受一个字符串,一个数组或一个Object / map作为NgClass的表达式。或者,当然,您可以指定一个返回其中一个的函数。

import {Component, CORE_DIRECTIVES} from 'angular2/angular2'

@Component({
  selector: 'my-app',
  directives: [CORE_DIRECTIVES],
  template: `
    <div>
      <h2>{{title}}</h2>
      <div ngClass="gray-border purple">string of classes</div>
      <div [ngClass]="'gray-border purple'">string of classes</div>
      <div [ngClass]="['gray-border', 'green']">array of classes</div>
      <div [ngClass]="{'gray-border': true, 'blue': true}">object/map of classes</div>
      <button [ngClass]="{active: isActive}" (click)="isActive = !isActive">Click me</button>
    </div>
  `,
  styles: [`
    .gray-border {  border: 1px solid gray; }
    .blue   { color: blue; }
    .green  { color: green; }
    .purple { color: purple; }
    .active { background-color: #f55; }
  `]
})
export class App {
  title = "Angular 2 - NgClass";
  isActive = false;
}

Plunker

如果要传递文字字符串,请注意两种替代语法:

<div ngClass="gray-border purple">string of classes</div>
<div [ngClass]="'gray-border purple'">string of classes</div>

我相信第一个只是第二个语法糖。

引用文档:

  

虽然NgClass指令可以解释求值的表达式   string,Array或Object,基于对象的版本最常见   使用并具有将所有CSS类名保留在一个中的优点   模板。

答案 1 :(得分:33)

您必须在CSSClass装饰器的directives属性中指定@View。看看这个plunk

@Component({
    selector: 'app',
})
@View({
    template: '<div [class]="classMap">Class Map</div>',
    directives: [CSSClass]
})
class App {
    constructor() {
        this.classMap = { 'class1': true, 'class2': false };

        setInterval(() => {
            this.classMap.class2 = !this.classMap.class2;
        }, 1000)
    }
}

UPD

alpha-35中的

CSSClass was renamedNgClass。见this plunk

@Component({
  selector: 'app',
})
@View({
  directives: [NgClass],
  template: `
    <div [ng-class]="classMap">Class Map</div>
  `,
})
class App { /* ... */ }

答案 2 :(得分:21)

另一种方法 [使用三元运算符和插值]

(Altough Mark Rajcok声明了所有可能的ngClass方法,但您可以将其与ternary operator结合使用,并获得else个条件

模板

<div class="hard-coded-class {{classCondition ? 'c1 c2': 'c3 c4'}}">
    Conditional classes using <b>Ternary Operator</b>
</div>

或使用ternary operatorngClasssee how

TS

export class App {
  this.classCondition = false;
}

结果

<div class="hard-coded-class c3 c4">
      Conditional classes using <b>Ternary Operator</b>
</div>

希望它有所帮助。

答案 3 :(得分:1)

我试图做类似的事情,我有一个菜单项列表,并希望为每个项目指定一个fontawesome类。这就是我的工作方式。在我的打字稿组件中,我有这个:

    export class AppCmp {
       menuItems = [
         {
           text: 'Editor',
           icon: 'fa fa-pencil'
         },
         {
           text: 'Account',
           icon: 'fa fa-user'
         },
         {
           text: 'Catalog',
           icon: 'fa fa-list'
         }
      ]
    }

然后在我的HTML中:

  <div *ngFor="#item of menuItems; #index = index">
        <i [attr.class]="item.icon"></i>
        <span>{{ item.text }}</span>
  </div>

以下是plunker,https://plnkr.co/edit/PIDRZsc7ZhISNgZzOWuY?p=preview 希望有所帮助