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

А зачем может понадобиться логика одного компонента в другом? Можно

пример пожалуйста

23 ответов

30 просмотров

Например локализация и форматирование данных

эта логика может быть не привязана к конкретному компоненту, она может быть общей и разные компоненты могут захотеть ее использовать банальный пример - отслеживание позиции курсора в реактивной обертке, чтобы можно было взять позицию и использовать ее как душе угодно в Composition API это будет выглядеть так: const { x, y } = useMouse(), где x и y - реактивные переменные, с которыми уже можно работать в Options API это будет выглядеть в лучшем случае так и будет доступно только в шаблоне: <Mouse v-slot=“{ x, y }”> {{ x }}, {{ y }} </Mouse> логика может быть и сложнее - это могут быть какие-то фичи, которые нужно расшарить между разными разделами, либо базовый функционал условного списка, когда у тебя в проекте может быть 200 списков

Алексей- Автор вопроса
Artyom Tuchkov
эта логика может быть не привязана к конкретному к...

А это логика может взаимодействовать с Vuex? Она же не является компонентом...

Artyom Tuchkov
эта логика может быть не привязана к конкретному к...

Вообще в Options можно писать так, как на обычном js, но это, конечно, запарнее, чем с composition API

Artyom Tuchkov
эта логика может быть не привязана к конкретному к...

Кстати, как mouse tracker реализовать не в script setup?

Alexey Topunov
Кстати, как mouse tracker реализовать не в script ...

в mounted устанавливаешь eventListener, в beforeUnmount убиваешь его

Vyacheslav Гайсин
в mounted устанавливаешь eventListener, в beforeUn...

Да, а в композабле одном как это написать?

Ну да, вопрос в том, что делать в такой ситуации

так же, как и в <script setup> если обычный Composition, то весь тот же самый код, только с дополнительным return если Options, то просто в mounted/unmounted, как ты и написал

Artyom Tuchkov
так же, как и в <script setup> если обычный Compos...

А как до хуков ЖЦ достучаться, если мы вызовем useMouse в методе setup?

Artyom Tuchkov
в какой такой?

Либо когда нет атрибута setup, либо на второй вьюшке/в опшн апи

Alexey Topunov
А как до хуков ЖЦ достучаться, если мы вызовем use...

точно так же, как и со <script setup> - импортировать onMounted и использовать

Alexey Topunov
Либо когда нет атрибута setup, либо на второй вьюш...

сформулируй полностью вопрос, я пока что-то не очень понимаю, о чем ты говоришь

Alexey Topunov
Либо когда нет атрибута setup, либо на второй вьюш...

Чего вы из Реакта все сюда лезете? Осенняя миграция?

Artyom Tuchkov
точно так же, как и со <script setup> - импортиров...

Хм, да, чёт мозг у меня съехал... Думал про script без сетапа, и сразу mounted() в свойства компонента у меня переместился 😄

Artyom Tuchkov
сформулируй полностью вопрос, я пока что-то не оче...

Нет, забей. С композишн понятно, просто невнимателелен был. А как с опшнс написать тот же useMouse?

Alexey Topunov
Нет, забей. С композишн понятно, просто невнимател...

ты можешь точно также писать рядом используя ref и reactive

Alexey Topunov
Нет, забей. С композишн понятно, просто невнимател...

в этом и был поинт, что в чистом Options ты не сделаешь точно такой же удобный аналог useMouse, как в Composition есть всякие костыли вроде миксинов и renderless-компонентов (как в моем примере), но они имеют свои минусы и неудобства

Artyom Tuchkov
в этом и был поинт, что в чистом Options ты не сде...

В данном случае, тут на что посмотреть

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

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

30500 за редактор? )
Владимир
47
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
вы делали что-то подобное и как? может есть либы готовые? увидел картинку нокода, где всё линиями соединено и стало интересно попробовать то же в ddl на lua сделать. решил с ч...
Victor
8
Подскажите пожалуйста, как в CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); получить наз...
A Z
7
Ребят в СИ можно реализовать ООП?
Николай
33
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
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
1
Он в одиночку это дело запилил или была какая-то команда?
Aquinary
12
~ 2m21s  nix shell github:nixos/nixpkgs#stack ~  stack ghc -- --version error: … while calling the 'derivationStrict' builtin at /builtin/derivation.nix:...
Rebuild your mind.
6
Всем привет, нужна как никогда, нужна помощь с IO в загрузчике. Пишу в code16 после установки сегментных регистров, пишу вывод символа. Пробовал 2 варианта: # 1 mov $0x0E, %a...
Shadow Akira
14
Карта сайта