[Angular 2] ng-class and Encapsulated Component Styles
2015-10-28 03:18
676 查看
import {Input, Component, View, NgClass} from "angular2/angular2"; @Component({ selector: 'todo-item-render' }) @View({ directives: [NgClass], styles: [` .started{ color: green; } .completed { text-decoration: line-through; } `], template: ` <div> <span [ng-class]="todoinput.status">{{todoinput.title}}</span> <button (click)="todoinput.toggle()">Toggle</button> </div> ` }) export class TodoItemRender{ @Input() todoinput: TodoModel; }
Many Components require different styles based on a set of conditions. Angular 2 helps you style your Components by allows you to define Styles inline, then choosing which styles to use based on the current values in your Controller.
You can define a static var on the TodoModel:
export class TodoModel{ static STARTED: string = "started"; static COMPLETED: string = "completed"; status: string = TodoModel.STARTED; constructor( public title: string = "" ){} toggle(): void{ if(this.status === TodoModel.STARTED) this.status = TodoModel.COMPLETED; else this.status = TodoModel.STARTED; } } export class TodoService{ todos: TodoModel[] = [ new TodoModel('eat'), new TodoModel('sleep'), new TodoModel('work') ]; addTodo(value: TodoModel):void { this.todos.push(value); } }
Then in the todoItemRender, you can require TodoModel and use the static var:
import {Input, Component, View, NgClass} from "angular2/angular2"; import {TodoModel} from './todoService'; @Component({ selector: 'todo-item-render' }) @View({ directives: [NgClass], styles: [` .${TodoModel.STARTED}{ color: green; } .${TodoModel.COMPLETED}{ text-decoration: line-through; } `], template: ` <div> <span [ng-class]="todoinput.status">{{todoinput.title}}</span> <button (click)="todoinput.toggle()">Toggle</button> </div> ` }) export class TodoItemRender{ @Input() todoinput: TodoModel; }
相关文章推荐
- angularjs 路由的使用
- AngularJs angular.uppercase、angular.lowercase、angular.fromJson、angular.toJson
- angular 继承和扩展
- angularjs-paste-upload
- AngularJS最常用的八种功能
- AngularJSb表单校验示例
- AngularJS 指令
- AngularJS 表达式
- AngularJS 简介
- 有关AngularJS请求Web API资源的思路
- angular 获取filter
- AngularJS开发人员最常犯的10个错误
- angularjs compile vs link
- Angularjs-Forms(表单)
- angular中通过事件获取ng-repeat中每个子项的属性
- AngularJS拖动窗口滑块以加载更多
- Angularjs-filter(过滤器)
- angular.bind使用心得
- [Angular 2] Passing data to components with @Input
- [Angular 2] Adding a data model