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

viewmodel?

17 ответов

34 просмотра

Пробрасывание 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 же делать

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

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

Портфолио: Зовут меня Александр, мне 36 лет. Город Пушкино. Общий рабочий стаж: ~14 лет Уровень квалификации: Senior Full-stack developer Где прочесть мой код? https://github....
Magic
10
Портфолио: Зовут меня Александр, мне 41 год. Город Киров. Общий рабочий стаж: ~14 лет Уровень квалификации: Senior Full-stack developer Где прочесть мой код? https://github.co...
Magic
11
Подскажите, пожалуйста, где в backende, или не в нем можно дату поправить? Логирует действия не в том часовом поясе
Лео
7
Есть магистры regex в чате? Задача: нужно написать regex который мэтчит полные (без сокращений по типу ::1/128) ipv6 адреса кроме 2001:0df7:cef7:29f7:52f7:adf7:2cf7:4ff7, при ...
Илья
5
Приветствую всех, есть вопросик. Передали проект на OctoberCms, без инсталяшки в полуразвернутом виде, нужно было залить бекап бд, после залития бд, оказалось, что части строк...
Лео
14
В чем может быть причина такого поведения? Библиотека есть, версия совпадает, но не собирается. Скармливаешь в rebar.lock - работает (потом отваливается другая, и так, пока не...
Δημήτηρ
2
Было открыто два проекта в Xcode. В одном делал билд, а в другом просто ковырялся. Проц разогрелся до 99 градусов, изображение на дисплее посыпалось и через 5 секунд комп выру...
Alexander Sherbakov
10
Привет! Подскажите может кто сталкивался, при создании купона выходит вот в таком виде окно. Как поправить это?
Ruslan
4
Всем привет. Понимаю, что вопрос, вероятно, будет крайне абстрактным, но все же. Что можно сделать с "Failed to fetch and copy dep", если это сторонняя зависимость сторонней б...
Δημήτηρ
3
Не читал, но осуждаю. Какая версия вапора? У нас при двойном запросе тоже падал, пока не обновили с патчем
Sergey
6
Карта сайта