169 похожих чатов

Добрый день, помогите, пожалуйста, понять логику работы Observable и Subject.



Допустим , у нас есть компонент, который хранит в себе логику изменения кол-ва сотрудников.
И должен в другой компонент, ./shared/, например отдавать результат. Я пробовала сначала через @Output отдать данные. Но пошли траблы другие, связанные с дизайном. Нужно чтобы много информации взаимодействовали с обьектом и вовремя изменялись во всех местах это кол-во сотрудников. В общем, решила переделать на сервис, вместо аутпута. Чтобы в любом месте можно было вызвать этих сотрудников. Но фишка в том, чтобы то где хранятся эти сотрудники, допустим три места. Нужно каждый раз , при изменении, обновлять во всех местах сразу. На помощь приходят Observable и Subject. В сервисе я подписуюсь

public listEmployeeSubject = new BehaviorSubject<any>();
public listEmployee = this.listEmployeeSubject.asObservable().pipe(distinctUntilChanged());

А вот дальше не совсем понимаю. Как вызываея этот сабж в компоненте, с ним правильно работать.
Т.е. в компоненте , в конструкторе - я должна подписаться subscribe на слежку обьекта?

По идее, вот так.

this.selectEmployeeService.listEmployeeSubject.next();
this.selectEmployeeService.listEmployee.subscribe((response) => {
this.listEmployee = response;
});
Но вот дальше у меня тупик. что делать дальше.

Мне использовать уже this.listEmployee, в который отдается response. Или нужно дальше работать с сабжом. Точнее , только с ним и работать. А уже он записывать все в обсервейбл переменную?!




____________

Я просто делаю переход с 1 ангуляра, на 7. И во многом разные концепции у них.

1 ответов

10 просмотров

все ок, только заместо subscribe в компоненте Вы можете преоборазовывать данные observable в нужный Вам вид с помощью rxjs операторов а дальше выводить в шаблоне через async pipe <div *ngFor="let item of listEmployee$ | async"> {{ item | json }} </div>

Похожие вопросы

Обсуждают сегодня

Какой-то там пердун в 90-х решил, что есть какая-то разная типизация. Кого вообще это волнует?
КТ315
49
void terminal_scroll() { memmove(terminal_buffer, terminal_buffer + VGA_WIDTH, buffer_size - VGA_WIDTH); memset(terminal_buffer + buffer_size - VGA_WIDTH, 0, VGA_WIDTH); ...
Егор
47
Всем привет! Подскажите, пожалуйста, в чем ошибка? Настраиваю подключение к MySQL. Либы лежат рядом с exe. Все как по "учебнику"
Евгений
16
А можете как-то проверить меня по знаниям по ассемблеру?
A A
132
Здравствуйте! У меня появилась возможность купить книгу "Изучай Haskell во имя добра!". Но я где-то слышал, что эта книга устарела. Насколько это правда??
E
22
Здравствуйте! Я вот на stepic решаю задачи на хаскеле https://stepik.org/lesson/8443/step/8?unit=1578 мой код import Data.List (isInfixOf) removing :: String -> [String] ->...
E
10
Камрады, кто тесно работал с vtv, хотел уточнить. Ширина column задаётся жёстко на этапе создания дерева или можно в рантайме ее менять программно (не мышкой)?
Ed Doc
10
да ладно ... что там неочевидного ? глянуть в исх-ки датасета и/или кверика чтобы понять в каком месте и как выполняется обращения к св-вам blablaSQL - минутное дело, даже е...
Сергей
7
Здесь для arm кто-нибудь кодит ?
Nothing
52
Всем привет, у меня есть сервер принимающий входящие HTTP подключения, как проверить, что подключение было через прокси или нет, есть какие то поля в заголовках по которым мо...
Кибер Бомж
8
Карта сайта