Zaczynam z RxJs (przy użyciu wersji beta wersji beta), ale jakoś nie mogę wymyślić, jak pracować z distinctUntilChanged
. Dane wyjściowe z poniższego kodu, jeśli uruchomię go w węźle Babel, to:Jak korzystać z RxJs distinctUntilChanged?
[ 'a', 1 ]
{ key: 'a', state: 1 }
Next: { value: 42 }
Completed
Nie tego się spodziewać. Dlaczego tylko jedna pozycja przechodzi distinctUntilChanged
? Spodziewam się, wyjście będzie
[ 'a', 1 ]
[ 'a', 0 ]
[ 'a', 1 ]
{ key: 'a', state: 1 }
{ key: 'a', state: 2 }
{ key: 'a', state: 0 }
{ key: 'a', state: 1 }
Next: { value: 42 }
Next: { value: 24 }
Completed
Oto kod
import {Observable} from 'rxjs'
Observable.of(['a', 1], ['a', 1], ['a', 0], ['a', 1])
.distinctUntilChanged(x => x[1])
.subscribe(x => console.log(x))
Observable.of({key: 'a', state: 1}, {key: 'a', state: 2}, {key: 'a', state: 0}, {key: 'a', state: 1})
.distinctUntilChanged(x => x.state)
.subscribe(x => console.log(x))
Observable.of({value: 42}, {value: 42}, {value: 24}, {value: 24})
.distinctUntilChanged(x => x.value)
.subscribe(
function (x) {
console.log('Next: ', x)
},
function (err) {
console.log('Error: ' + err)
},
function() {
console.log('Completed')
}
)
links w docs V5 dla tych funkcji wydaje się być martwy
------ edit - ---
Niektóre dodatkowe debugowanie:
Observable.of(['a', 1], ['a', 1], ['a', 0], ['a', 1])
.do(x => console.log('before', x))
.distinctUntilChanged(x => x[1])
.do(x => console.log('after', x))
.subscribe(x => console.log(x))
wyjściowa:
before [ 'a', 1 ]
after [ 'a', 1 ]
[ 'a', 1 ]
before [ 'a', 1 ]
before [ 'a', 0 ]
before [ 'a', 1 ]
Również dla tego rodzaju debugowania pytanie, należy uwzględnić oczekiwane zachowanie, a najlepiej pokazać pewne próby debugowania. – user3743222
OK Dodałem oczekiwane wyjście –