пример пожалуйста
Например локализация и форматирование данных
эта логика может быть не привязана к конкретному компоненту, она может быть общей и разные компоненты могут захотеть ее использовать банальный пример - отслеживание позиции курсора в реактивной обертке, чтобы можно было взять позицию и использовать ее как душе угодно в Composition API это будет выглядеть так: const { x, y } = useMouse(), где x и y - реактивные переменные, с которыми уже можно работать в Options API это будет выглядеть в лучшем случае так и будет доступно только в шаблоне: <Mouse v-slot=“{ x, y }”> {{ x }}, {{ y }} </Mouse> логика может быть и сложнее - это могут быть какие-то фичи, которые нужно расшарить между разными разделами, либо базовый функционал условного списка, когда у тебя в проекте может быть 200 списков
А это логика может взаимодействовать с Vuex? Она же не является компонентом...
Вообще в Options можно писать так, как на обычном js, но это, конечно, запарнее, чем с composition API
Кстати, как mouse tracker реализовать не в script setup?
в mounted устанавливаешь eventListener, в beforeUnmount убиваешь его
Да, а в композабле одном как это написать?
Ну да, вопрос в том, что делать в такой ситуации
так же, как и в <script setup> если обычный Composition, то весь тот же самый код, только с дополнительным return если Options, то просто в mounted/unmounted, как ты и написал
А как до хуков ЖЦ достучаться, если мы вызовем useMouse в методе setup?
Либо когда нет атрибута setup, либо на второй вьюшке/в опшн апи
точно так же, как и со <script setup> - импортировать onMounted и использовать
сформулируй полностью вопрос, я пока что-то не очень понимаю, о чем ты говоришь
Чего вы из Реакта все сюда лезете? Осенняя миграция?
Хм, да, чёт мозг у меня съехал... Думал про script без сетапа, и сразу mounted() в свойства компонента у меня переместился 😄
Нет, забей. С композишн понятно, просто невнимателелен был. А как с опшнс написать тот же useMouse?
написать в функции setup() {}
ты можешь точно также писать рядом используя ref и reactive
в этом и был поинт, что в чистом Options ты не сделаешь точно такой же удобный аналог useMouse, как в Composition есть всякие костыли вроде миксинов и renderless-компонентов (как в моем примере), но они имеют свои минусы и неудобства
А без reactivity API?
В данном случае, тут на что посмотреть
Обсуждают сегодня