Han*_*Che 6 data-binding two-way angular2-services angular
我需要澄清服务和组件属性之间的绑定以及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();
}
}
Run Code Online (Sandbox Code Playgroud)
Angular绑定仅适用于视图(HTML)中声明的绑定.
如果您希望在服务中的值发生更改时更新组件中的属性,则需要自己处理.
Observables使这很容易.有关示例,请参阅检测组件输入的嵌套属性的更改.
如果您通过引用更新元素(如果您将某些内容更新到object属性中),您将在视图中看到更新:
export class Service {
(...)
updateObject() {
this.object.id = 2;
}
}
Run Code Online (Sandbox Code Playgroud)
如果按值更新元素(如果将某些内容更新到name属性中),则不会在视图中看到更新:
export class Service {
(...)
updateName() {
this.name = 'Luke1';
}
}
Run Code Online (Sandbox Code Playgroud)
请参阅此plunkr:https://plnkr.co/edit/w7bS0fAVjOc3utnpD39b ? p = preview .
| 归档时间: |
|
| 查看次数: |
10252 次 |
| 最近记录: |