我不清楚Subject和BehaviorSubject之间的区别。是否只是BehaviorSubject具有getValue函数?
答案 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
另外:
答案 1 :(得分:162)
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
答案 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