Comment utiliser RxJs distinctUntilChanged?

Je suis arriver a commencé avec RxJs (à l'aide de la v5 beta), mais de toute façon je ne peux pas comprendre comment travailler avec distinctUntilChanged. La sortie à partir du code ci-dessous si je le lance dans babel-nœud est

[ 'a', 1 ]
{ key: 'a', state: 1 }
Next:  { value: 42 }
Completed

Qui n'est pas ce que je m'attends. Pourquoi est-ce qu'une entrée en passant distinctUntilChanged? J'attendrais la sortie de la

[ '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

Voici le code

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')
    }
  )

La liens dans la v5 docs pour ces fonctions semblent être morts

------ edit -----

Supplémentaire de débogage:

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))

de sortie:

before [ 'a', 1 ]
after [ 'a', 1 ]
[ 'a', 1 ]
before [ 'a', 1 ]
before [ 'a', 0 ]
before [ 'a', 1 ]
  • Aussi, pour ce genre de débogage question, vous devez inclure le comportement attendu et, idéalement, de montrer quelques tentatives de débogage.
  • OK j'ai ajouté de la sortie attendue de