Subject和BehaviorSubject有什么区别?

时间:2017-04-11 14:12:01

标签: rxjs

我不清楚Subject和BehaviorSubject之间的区别。是否只是BehaviorSubject具有getValue函数?

6 个答案:

答案 0 :(得分:184)

BehaviorSubject包含一个值。订阅时,它会立即发出值。主题没有保留值。

主题示例(使用RxJS 5 API):

const subject = new Rx.Subject();
subject.next(1);
subject.subscribe(x => console.log(x));

控制台输出为空

BehaviorSubject示例:

const subject = new Rx.BehaviorSubject();
subject.next(1);
subject.subscribe(x => console.log(x));

控制台输出:1

另外:

  • 可以使用初始值创建BehaviorSubject:new Rx.BehaviorSubject(1)
  • 如果您希望主题包含多个值,请考虑使用ReplaySubject

答案 1 :(得分:162)

BehaviourSubject

BehaviourSubject将返回订阅的初始值或当前值

var subject = new Rx.BehaviorSubject(0);  // 0 is the initial value

subject.subscribe({
  next: (v) => console.log('observerA: ' + v)  // output initial value, then new values on `next` triggers
});

subject.next(1);  // output new value 1 for 'observer A'
subject.next(2);  // output new value 2 for 'observer A', current value 2 for 'Observer B' on subscription

subject.subscribe({
  next: (v) => console.log('observerB: ' + v)  // output current value 2, then new values on `next` triggers
});

subject.next(3);

输出:

observerA: 0
observerA: 1
observerA: 2
observerB: 2
observerA: 3
observerB: 3

主题

主题不会返回Subscription上的当前值。它仅在.next(value)调用时触发,并返回/输出value

var subject = new Rx.Subject();

subject.next(1); //Subjects will not output this value

subject.subscribe({
  next: (v) => console.log('observerA: ' + v)
});
subject.subscribe({
  next: (v) => console.log('observerB: ' + v)
});

subject.next(2);
subject.next(3);

在控制台上输出以下内容:

observerA: 2
observerB: 2
observerA: 3
observerB: 3

答案 2 :(得分:9)

它可以帮助您理解。

const map = new Map()
const arr = [0,1,2,3];
map.set(arr, "I am some number")

// Get a reference to the same `arr` whose key you set previously:
const arrKey = [...map.keys()].find(
  key => Array.isArray(key) && JSON.stringify(key) === JSON.stringify([0, 1, 2, 3])
);
console.log(map.get(arrKey));

答案 3 :(得分:4)

我刚刚创建了一个项目,它解释了所有主题之间的差异是什么:
https://github.com/piecioshka/rxjs-subject-vs-behavior-vs-replay-vs-async

enter image description here

答案 4 :(得分:0)

BehaviourSubject将可观察对象发出的最后一个值保留在内存中。 普通科目不要。

BehaviourSubject类似于ReplaySubject,缓冲区大小为1。

答案 5 :(得分:0)

BehaviorSubject 在订阅后发出一个值,一个 Subject 编号。

// Subject
const mySubject = new Rx.Subject().subscribe((v) => console.log(v)); // will return nothing

// BehaviorSubject
const myBehaviorSubject = new Rx.BehaviorSubject(666).subscribe((v) => console.log(v)); // will return 666 when subscription occurs