у меня строка хранится в сервисе, я её могу сразу в компоненте выводить через {{this.someService.someText}}? Просто столкнулся с тем, что если изменение вызвано из компонента - то всё ок, а если строка меняется в самом сервисе, то ангуляр не перерисовывает приложение пока не будет какого-то взаимодействия в компоненте. Я к тому, что как лучше и проще в таком случае отслеживать изменения строки в сервисе? Через EventEmitter или BehaviourSubject?
через сабжект любой, зависит от ситуации
храни значение строки в каком-нибудь сабжекте и меняй его next-ом, а в шаблоне просто заюзай async pipe для вывода.
А можно чуть подробнее, как это гуглить, чтоб понять как оно выглядит и работает?
дык это, документация rxjs в помощь...
А, понял, я думал что-то чисто ангулярное. Спасибо большое!
ну ангуляр плотно работает с rxjs, от ангуляра потребуется только async pipe, когда вы подготовите себе какой-то объект с обсёрваблом (сабжекты тоже обсерваблы)
На сервисе заводишь свойство типа Subject/BehaviorSubject и меняешь его состояние next'ом. На компоненте просто импортишь сервис как публичный член класса, он появится на this. В шаблоне используешь 'serviceName.value$ | async' . Хорошим тоном будет завести на сервисе публичное свойство типа Observable со значением subject.asObservable() и в шаблоне компонента использовать его.
ага, с BehaviorSubject работал, понял. redux развращает, привык уже что данные откуда угодно можно менять.
менять можно откуда угодно) главное, чтоб это было в зоне доступности чейндждетектора)
Обсуждают сегодня