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

Кто может объяснить такое поведение подписок в шаблоне: card$ = this.service.card$;

// Данные приходят сюда
cardImage$ = this.card.pipe(// GET IMAGE);

Шаблон:

<ng-container ngif="card$ | async">
<ng-container ngif="cardImage | async">IMG</ng-container>
</ng-container>

Проблема в том что если данные пришли в card$ карточка открывается. А вот картинка не отображается.
Если все переписать так:

public card;
public image;
this.service.card$.subscribe((e => card = e);
this.card.subscribe((e => image = e);

Шаблон:

{{card}}
{{image}}

В таком варианте все прекрасно работает.
Кто может объяснить как разруливать асинхронщину в шаблоне правильно?

16 ответов

0 просмотров

а зачем там тебе вложенность?

Oleh-P Автор вопроса
🎋🎋🥷 ngSamurai 🏯🎋🎋
а зачем там тебе вложенность?

первый if в шаблоне создает контейнер с данными. в нем уже другой if который помещает картинку. как-то так.

Oleh-P Автор вопроса
🎋🎋🥷 ngSamurai 🏯🎋🎋
а зачем там тебе вложенность?

как-раз чтобы как-то полотенце укоротить разбил на несколько потоков. В один поток будет очень сложно

Oleh P
как-раз чтобы как-то полотенце укоротить разбил на...

не.. я имел ввиду что если все разбито на потоки..то потом в итоговый снова собрать и в шаблоне только одну подписку иметь..

Oleh-P Автор вопроса

что заюзать чтобы собрать в один пайп? сначала прослушиваем card в ней подписываемся на второй поток image и мапим обратно уже с картинкой в новый new$: Observable?

Oleh P
что заюзать чтобы собрать в один пайп? сначала про...

https://www.danywalls.com/combine-async-pipes-in-angular-how-to-avoid-multiple-pipes

Oleh-P Автор вопроса
Oleh P
идеально - это мой кейс

combineLatest уже давно умеет принимать на вход объект

Oleh-P Автор вопроса
Oleh P
объект Observable?

combineLatest({ player: this.getPlayer(), stats: this.getStats() });

Oleh-P Автор вопроса
🎋🎋🥷 ngSamurai 🏯🎋🎋
https://www.danywalls.com/combine-async-pipes-in-a...

минус подохода в том что если хотя бы один поток умрет или вернет ошибку - то карточка не подтянется. Например местами нет картинки. Поэтому изначально был в этом и смысл что карточку подтягивать асинхронно разными потоками

Oleh P
минус подохода в том что если хотя бы один поток у...

да.. но при условии что произошло исклбючение всегда можно оф.нуть пустую карту и вывести ошибку

Oleh-P Автор вопроса
🎋🎋🥷 ngSamurai 🏯🎋🎋
да.. но при условии что произошло исклбючение всег...

т-е всегда обрабатывать исключения и ошибки - чтобы не ломать поток? и вернуть скажем new Error и в шаблоне проверять если это так - то показать в нужном блоке вместо картинки ошибку?

Oleh-P Автор вопроса
🎋🎋🥷 ngSamurai 🏯🎋🎋
чтото в этом духе

было бы хорошо показать часть данных карточки и часть подгружать в процессе - но блин - возвращаемся к проблеме

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

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

а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
Эх кто-то пришел и весь праздник испортил :( You need complex FBX scene importing setup to change things on import? good luck with that. You need navigation and pathfinding? g...
Serg Gini
5
Всем привет! Подскажите. Я написал приложение на Delphi 10.2 Tokyo под Windows 10. И передо мной стал вопрос о том чтобы сделать это приложение кроссплатформенным (под Linux и...
Дмитрий Завгородний
24
Какого хера? /Sources/App/Modules/User/Models/UserLinkApple.swift:21:20: warning: stored property '_id' of 'Sendable'-conforming class 'UserLinkApple' is mutable @ID(...
Alexander Sherbakov
14
Привет всем. Подскажите где можно посмотреть, какая версия электрон, поддерживает версии windows? Некий changelog. Мне бы желательно, поддержку 7,8,10... latest, как понимаю и...
Anonym Squad
21
Почему стало ломаться на D11? "739002.86400000' is not a valid timestamp" function IncDateTime(aStamp:TTimeStamp;aKind:TTriggerKind;aInterval:Integer):TDateTime; //aStamp = 2...
Катерина Свиридова
8
У тебя в конфиге нигде нет deny all; или вообще любого deny?
Alexander Sherbakov
10
Портфолио: Зовут меня Александр, мне 36 лет. Город Пушкино. Общий рабочий стаж: ~14 лет Уровень квалификации: Senior Full-stack developer Где прочесть мой код? https://github....
Magic
10
Есть ли смысл устраиваться на 1с ? Даст это плюс в дальнейшем трудоустройстве на php? Просто у меня в городе вакансий на пхп нету. Или лучше удаленно искать. Опыта работы нету...
Azamat
14
Ребят, чет я уже не догоняю... Крч в коде на асм там происходит нечто вроде a+число (a+1, a+2 и т.д.). Но почему строка lea ecx, [edx+1] работает как a+1?? В edx берется адрес...
Alan 🔝 Бэброу
4
Карта сайта