服务和组件属性之间的angular2数据绑定
angular2 data binding between service and component properties
我需要对服务和组件属性之间的绑定以及 angular2 中的数据绑定进行一些说明
假设我有一个服务(单例)和一个组件
export class Service {
name = "Luke";
object = {id:1};
getName(){return this.name};
getObject(){return this.object};
}
export class Component implements OnInit{
name:string;
object:any;
constructor(private _service:Service){}
ngOnInit():any{
//Is this 2 way binding?
this.name = this._service.name;
this.object = this._service.object;
//Is this copying?
this.name = this._service.getName();
this.object = this._service.getObject();
}
}
Angular 绑定仅适用于视图中声明的绑定 (HTML)。
如果您希望在服务中的值更改时更新组件中的属性,您需要自己处理。
Observables 让这变得简单。有关示例,请参阅 detect change of nested property for component input。
如果您通过引用更新元素(如果您将某些内容更新到 object
属性),您将在视图中看到更新:
export class Service {
(...)
updateObject() {
this.object.id = 2;
}
}
如果您按值更新元素(如果您将某些内容更新到 name
属性),您将不会在视图中看到更新:
export class Service {
(...)
updateName() {
this.name = 'Luke1';
}
}
看到这个 plunkr:https://plnkr.co/edit/w7bS0fAVjOc3utnpD39b?p=preview。
如果您希望组件中的属性在服务中的值更改时立即更新:
- 将
DoCheck
从 @angular/core
和您的 service
导入
组件。
- 在
ngDoCheck(){...}
中调用影响组件属性的服务函数
- 组件视图将在任何更改时自动更新
你的组件中有这样的东西:
ngDoCheck() {
this.qty = this.cartService.getTotalQtyInCart();
}
我需要对服务和组件属性之间的绑定以及 angular2 中的数据绑定进行一些说明
假设我有一个服务(单例)和一个组件
export class Service {
name = "Luke";
object = {id:1};
getName(){return this.name};
getObject(){return this.object};
}
export class Component implements OnInit{
name:string;
object:any;
constructor(private _service:Service){}
ngOnInit():any{
//Is this 2 way binding?
this.name = this._service.name;
this.object = this._service.object;
//Is this copying?
this.name = this._service.getName();
this.object = this._service.getObject();
}
}
Angular 绑定仅适用于视图中声明的绑定 (HTML)。
如果您希望在服务中的值更改时更新组件中的属性,您需要自己处理。
Observables 让这变得简单。有关示例,请参阅 detect change of nested property for component input。
如果您通过引用更新元素(如果您将某些内容更新到 object
属性),您将在视图中看到更新:
export class Service {
(...)
updateObject() {
this.object.id = 2;
}
}
如果您按值更新元素(如果您将某些内容更新到 name
属性),您将不会在视图中看到更新:
export class Service {
(...)
updateName() {
this.name = 'Luke1';
}
}
看到这个 plunkr:https://plnkr.co/edit/w7bS0fAVjOc3utnpD39b?p=preview。
如果您希望组件中的属性在服务中的值更改时立即更新:
- 将
DoCheck
从@angular/core
和您的service
导入 组件。 - 在
ngDoCheck(){...}
中调用影响组件属性的服务函数
- 组件视图将在任何更改时自动更新
你的组件中有这样的东西:
ngDoCheck() {
this.qty = this.cartService.getTotalQtyInCart();
}