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

Как смотреть изменения массива примитивов? Через watch и computed видит

только добавление/удаление элементов, но не изменения их самих.

15 ответов

20 просмотров

есть deep: true, но только если очень нада

если vue 2 и ты мутируешь элементы прям по индексу типа array[0] = 1, то https://vuejs.org/v2/guide/reactivity.html#For-Arrays

А ты пробовал менять массив? Иммутабельным делать

Ivan-Tseloban Автор вопроса
Kostya bah
А ты пробовал менять массив? Иммутабельным делать

Там два простых компонента: 1. Компонент списка товаров. prop: value - массив строк. В шаблоне итерируемся v-for по элементам пропа и монтируем компоненты №2. В конце кнопка, при нажатии на которую можно добавить еще одну пустую строку в массив. Отображается, если все предыдущие заполнены. Тут же обрабатываются события из компонентов №2 и происходит запись в стейт. 2. Компонент -обычный текстовый инпут. prop: value - строка. Массив берется из родителя первого компонента, тот в свою очередь тянет его из стейта. В этот раз попробовал наколбасить на v-model'ах, но оказывается там много подводных, и все равно "красиво" не получается.

Ivan Tseloban
Там два простых компонента: 1. Компонент списка то...

И что мутируешь стейт ничего не получается? Создай новый массив

Ivan-Tseloban Автор вопроса
Kostya bah
И что мутируешь стейт ничего не получается? Создай...

Стейт мутируется ок. Компонент №1 получает данные из родителя через v-model. И проп "value" также соответствует стейту. Однако условие отображения кнопки "добавить" не отрабатывает. Видит только изменение кол-ва элементов массива, но не самих элементов. Сейчас кнопка завязана на "show". Отслеживается следующим образом: watch: { value: { deep: true, handler(val) { console.log(val); this.show = val.every((item) => !!item); }, }, },

Ivan Tseloban
Стейт мутируется ок. Компонент №1 получает данные ...

Я как пончл если item пустой хоть один то закрывается иначе открыт

Ivan-Tseloban Автор вопроса
Kostya bah
Я как пончл если item пустой хоть один то закрыва...

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

Ivan-Tseloban Автор вопроса
Kostya bah
А как ты мутируешь....

SET_MEDIA_ITEM(state, { value, index }) { // this._vm.$set(state.currentItem.items, index, value); // state.currentItem.items.splice(index, 1, value); state.currentItem.items[index] =value; }, Первые две строки отрабатывают, но после кадого изменения фокус с инпутов пропадает.

Ivan Tseloban
SET_MEDIA_ITEM(state, { value, index }) { ...

Так плохо делать используй модули)))

Ivan-Tseloban Автор вопроса
Kostya bah
Так плохо делать используй модули)))

Это и есть модуль. Прилетает жирный объект с бека, который нужно впихнуть в форму. Делать отдельный модуль для каждого непримитива это оверинжениринг уже)

Ivan Tseloban
Это и есть модуль. Прилетает жирный объект с бека...

Ттебе нужно создать новый currentItem, или модульное состояние сделать и через items.map поменять массив

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

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

30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
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
~ 2m21s  nix shell github:nixos/nixpkgs#stack ~  stack ghc -- --version error: … while calling the 'derivationStrict' builtin at /builtin/derivation.nix:...
Rebuild your mind.
6
Карта сайта