В чем разница между субъектом и поведением субъекта?

251

Я не понимаю разницу между а Subjectи а BehaviorSubject. Это просто BehaviorSubjectимеет getValue()функцию?

Майк Джерред
источник

Ответы:

312

BehaviorSubject содержит одно значение. Когда он подписан, он немедленно выдает значение. Предмет не имеет значения.

Пример темы (с RxJS 5 API):

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

Консольный вывод будет пустым

Пример поведения субъекта:

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

Консольный выход: 1

К тому же:

  • BehaviorSubject может быть создан с начальным значением: новый Rx.BehaviorSubject(1)
  • Подумайте ReplaySubject, хотите ли вы, чтобы объект содержал более одного значения
ZahiC
источник
16
Итак, вы имеете в виду, что вы должны подписаться на subject перед subject.next (), чтобы это работало?
Эрик Хуанг,
5
@eric для субъекта, да. Это различие.
onefootswill
9
Обратите внимание, что вы должны передать первое значение конструктору BehaviorSubject;)
mrmashal
если мы создадим тему с логическим значением, даже тема испускает обряд ?? const subject = новый Subject <логический> (); subject.next (истина);
user2900572
Если это поможет: Subjects = Event - BehaviorSubject = State;
Джонатан Стеллваг
251

BehaviourSubject

BehaviourSubject вернет начальное значение или текущее значение в подписке

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

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

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

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

bSubject.next(3);

С выходом:

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

Тема

Субъект не возвращает текущее значение в подписке. Он срабатывает только при .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
Мохаммед Сейфер
источник
12
Это также более правильно: «BehaviourSubject вернет начальное значение или текущее значение в подписке» - это лучшее объяснение, чем «BehaviorSubject содержит одно значение».
Дэви
1
Я поместил приведенный выше код в Stackblitz: stackblitz.com/edit/rxjs-subjectvsbehaviorsubject
Fredrik_Macrobond
Где наблюдатель B: 3?
ОПВ
@OPV ObserverB: 3 там, пока вы звонитеsubject.next(3);
Мохаммед Сейфер
6

Это может помочь вам понять.

import * as Rx from 'rxjs';

const subject1 = new Rx.Subject();
subject1.next(1);
subject1.subscribe(x => console.log(x)); // will print nothing -> because we subscribed after the emission and it does not hold the value.

const subject2 = new Rx.Subject();
subject2.subscribe(x => console.log(x)); // print 1 -> because the emission happend after the subscription.
subject2.next(1);

const behavSubject1 = new Rx.BehaviorSubject(1);
behavSubject1.next(2);
behavSubject1.subscribe(x => console.log(x)); // print 2 -> because it holds the value.

const behavSubject2 = new Rx.BehaviorSubject(1);
behavSubject2.subscribe(x => console.log('val:', x)); // print 1 -> default value
behavSubject2.next(2) // just because of next emission will print 2 
Санджит Кумар
источник
4

BehaviorSubjectсохраняет в памяти последнее значение, которое было получено наблюдаемой. Обычный Subjectнет.

BehaviorSubjectкак ReplaySubjectс размером буфера 1.

Моше Черныш
источник