только добавление/удаление элементов, но не изменения их самих.
есть deep: true, но только если очень нада
не работает
если vue 2 и ты мутируешь элементы прям по индексу типа array[0] = 1, то https://vuejs.org/v2/guide/reactivity.html#For-Arrays
А ты пробовал менять массив? Иммутабельным делать
Там два простых компонента: 1. Компонент списка товаров. prop: value - массив строк. В шаблоне итерируемся v-for по элементам пропа и монтируем компоненты №2. В конце кнопка, при нажатии на которую можно добавить еще одну пустую строку в массив. Отображается, если все предыдущие заполнены. Тут же обрабатываются события из компонентов №2 и происходит запись в стейт. 2. Компонент -обычный текстовый инпут. prop: value - строка. Массив берется из родителя первого компонента, тот в свою очередь тянет его из стейта. В этот раз попробовал наколбасить на v-model'ах, но оказывается там много подводных, и все равно "красиво" не получается.
И что мутируешь стейт ничего не получается? Создай новый массив
Стейт мутируется ок. Компонент №1 получает данные из родителя через v-model. И проп "value" также соответствует стейту. Однако условие отображения кнопки "добавить" не отрабатывает. Видит только изменение кол-ва элементов массива, но не самих элементов. Сейчас кнопка завязана на "show". Отслеживается следующим образом: watch: { value: { deep: true, handler(val) { console.log(val); this.show = val.every((item) => !!item); }, }, },
Я как пончл если item пустой хоть один то закрывается иначе открыт
Да. Собственно сейчас когда добавляем один пустой итем, кнопка пропадает и больше не возвращается, даже если изменять последний добавленный итем
А как ты мутируешь....
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; }, Первые две строки отрабатывают, но после кадого изменения фокус с инпутов пропадает.
Так плохо делать используй модули)))
Это и есть модуль. Прилетает жирный объект с бека, который нужно впихнуть в форму. Делать отдельный модуль для каждого непримитива это оверинжениринг уже)
Ттебе нужно создать новый currentItem, или модульное состояние сделать и через items.map поменять массив
Обсуждают сегодня