А норм ли со стороны хорошой практики пробрасывать NavController во

viewmodel?

17 ответов

78 просмотров

Пробрасывание NavController в ViewModel считается нарушением принципов архитектуры MVVM (Model-View-ViewModel). Вот почему: 1. Смешение ответственностей: ViewModel должна заниматься обработкой бизнес-логики и предоставлением данных для отображения. Управление навигацией — это часть ответственности View. 2. Тестирование: ViewModel с NavController будет сложнее тестировать. Вы должны будете подменять NavController или использовать другие подходы для изоляции ViewModel в юнит-тестах. 3. Переиспользование: ViewModel с проброшенным NavController будет менее переиспользуемым, так как он привязан к конкретной навигационной логике. Похоже на правду?

Igor
Пробрасывание NavController в ViewModel считается ...

Не сильно. Управлением навигацией может заниматься и бизнес-логика. Например, открыть экран по какому-то событию или при переходе по диплинку. Во многих нав-библиотеках для композа и не только так и происходит. Выносить ли стейт-объекты в композицию или хоистить их внутри компонентов бизнес-логики – зависи от конкретного юзкейса. Точно так же и стейты виджетов (LazyListState) могут хоиститься так и внутри композиции, так и внутри бизнес-логики.

Igor
Пробрасывание NavController в ViewModel считается ...

Ты спрашиваешь у чата, лайк или дизлайк этому ответу поставить?)

NavController ведь живёт в скоупе своей Composable-функции, а у ViewModel скоуп шире. Утечка же будет.

Ну я так и понял)

Как это поможет?

Arkadii Ivanov
Как это поможет?

А, погодь, я не так тебя понял. Ты про хостинг контроллера во вью модели, которая андроидовская, и которая переживает активити

Нет

Arkadii Ivanov
NavController ведь живёт в скоупе своей Composable...

При желании можно сделать, чтобы не было утечек. У нас обертка над navcobtroller инжектится в VM. А так же инжектится в активити/фрагмент. В активити/фрагменте аттачится/детачится в onCreate/onDestroy. Утечек нет и можно дергать обертку в vm для навигации. Но с композом такой поход становится не очень. Поэтому мы по возможности от этого избавляемся. Из VM выбрасываем наверх события навигации и потом дергаем коллбеки из композаблов, которые уже выполняют навигацию.

anonim-qwerty Автор вопроса

а что за утечка

Pavel
При желании можно сделать, чтобы не было утечек. У...

Ну это же не сам NavController, про который шла речь. 😀 А если это VM экрана в стеке? Костыльно как-то получается.

anonim-qwerty Автор вопроса
anonim qwerty
А как?

NavController зависит от контекста

anonim-qwerty Автор вопроса
Arkadii Ivanov
NavController зависит от контекста

иии? как это приведет к утечке памяти?

Pavel
При желании можно сделать, чтобы не было утечек. У...

а в чём проблема с композом при таком подходе? мы так собираемся делать как раз, так то в классическом MVVM навигацию рекомендуется как раз из viewmodel же делать

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

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

Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Раз начали говорить про embassy, то присоединюсь со своими парой вопросов. 1) Есть ли сопоставимые аналоги для асинхронного кода в emdebbed? 2) Можно ли внутри задач embassy ...
NI_isx
6
Всем привет, нужна как никогда, нужна помощь с IO в загрузчике. Пишу в code16 после установки сегментных регистров, пишу вывод символа. Пробовал 2 варианта: # 1 mov $0x0E, %a...
Shadow Akira
14
Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
2
Коллеги, я тут для личных нужд пошел ставить MQTT сервер, пощупал mosquitto, но ужаснулся отсутствию такой банальности, как HTTP API для посмотреть список топиков. А тут что,...
Maksim Lapshin
14
У меня задача: написать брокер сообщений. Очереди и потребители. Очереди поддерживают приоритеты. Очередь отдает сообщения, только обработчикам с соответствующими характеристи...
Aleksandr Filippov
2
Решил тут попробовать embassy на bluepill. Все установил, собрал blink и успешно залил с помощью St link 2 китайского. Но после этого чип шиться перестал. На форумах прочел, ч...
Lukutin R2AJP
6
Привет!) Кто как юзает переменные в строках?) Чисто ради интереса Вот так: echo "У меня {$bananasAmount} бананов"; Или вот так: echo "У меня ${bananasAmount} бананов";
Виталий
3
Карта сайта