mar*_*cel 8 typescript angular
我想观看一个对象/数组,可以通过服务或控制器例程进行编辑.我以为Observable可以观看一个对象/数组.
我的实现不会对项目的更改做出反应:
private data : Observable<Array<any>>;
private dataObserver: Observer<Array<any>>;
private sub : Subscription;
private items: <Array<any>>;
ngOnInit() {
this.items = itemService.getItems();
this.data = new Observable<Array<any>>(observer =>{
this.dataObserver = observer;
});
this.data.subscribe(
x => console.log('onNext: %s', x),
e => console.log('onError: %s', e),
() => console.log('onCompleted')
);
this.dataObserver.next(this.items);
}
private start(){
//change values of the array in an interval
let loop = Observable.interval(250)
let i=0;
self.sub = loop.subscribe(() => {
if(self.items[0]){
self.items[0].id= i;
if(i<100) i++;
else i=1;
}
})
}
Run Code Online (Sandbox Code Playgroud)
subsvaltion subsciption不会对items数组的更改做出反应.它只会在下一个mehtod上触发.另一方面..这对于简单的手表方法来说太麻烦了.
angular-2为我们提供了什么样的变化,就像$ scope一样.$ watch在angular-1中做了什么?
Gün*_*uer 14
Angular2提供IterableDiffer(数组)和KeyValueDiffer(对象)以获取有关两个检查之间差异的信息.
另见https://angular.io/docs/ts/latest/api/#!?query=differ
一个例子
// inject a differ implementation
constructor(differs: KeyValueDiffers) {
// store the initial value to compare with
this.differ = differs.find({}).create(null);
}
@Input() data: any;
ngDoCheck() {
var changes = this.differ.diff(this.data); // check for changes
if (changes && this.initialized) {
// do something if changes were found
}
}
Run Code Online (Sandbox Code Playgroud)
在导入部分:
import { DoCheck, KeyValueDiffers, KeyValueChangeRecord } from '@angular/core';
Run Code Online (Sandbox Code Playgroud)
添加“ KeyValueDiffers”注入器:
private _differ: any;
constructor(private _differs: KeyValueDiffers) {
this._differ = _differs.find({}).create();
}
Run Code Online (Sandbox Code Playgroud)
最后跟踪更改:
ngDoCheck() {
const change = this._differ.diff(this.Your_Object_To_Track);
if (change) {
change.forEachChangedItem(
(record: KeyValueChangeRecord<any, any>) => {
console.log(record.key + ': ' + record.previousValue + '=>' + record.currentValue) });
change.forEachRemovedItem(
(record: KeyValueChangeRecord<any, any>) => {
console.log(record.key + ': ' + record.previousValue + '=>' + record.currentValue) });
change.forEachAddedItem((record: KeyValueChangeRecord<any, any>) => {
console.log(record.key + ': ' + record.previousValue + '=>' + record.currentValue) });
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
8275 次 |
| 最近记录: |