меня есть такая проблема. Я передаю филды объекта в компонент через v-bind, и при изменении полей объекта проперти не меняются. Но если передаю целиком как проперти, то все ок.
Объект это не простой. У него для каждого филда есть свои getters/setters. Похоже они и дают это некорректное поведение.
Может кто подскажет, где посмотреть в source code как реализована работа v-bind? Что-то сам я с ходу не нашел
Как меняешь внутри компонента?
Я скрин выше прикладывал. значение меняется. вернее так: :param="param" - тут в проперти видно что значение поменялось v-bind="param" - а тут старое значение - хотя объект один и тот же
> при изменении полей объекта проперти не меняются Где кто как меняет поля какого объекта?)
Код v-bind, если нужен, тут https://github.com/vuejs/vue/blob/dev/src/core/instance/render-helpers/bind-object-props.js
смотри. вот накидал упрощенный варинт https://codesandbox.io/s/funny-swanson-s8fn0?file=/src/App.vue
Да, так работать не будет. В obj хранится прокси к нереактивному объекту. В изменении через прокси изменяется нереактивный объект. Прокси не становится реактивным, как объект
хотя смотрю как работает реактивность в вью https://github.com/vuejs/vue/blob/dev/src/core/observer/index.js#L67 https://github.com/vuejs/vue/blob/dev/src/core/observer/index.js#L144 вот попробовал в консольке запустить: const target = { message: 'test' } const handler1 = { get: function(target, prop, receiver) { return 'handler1 ' + target.message }} const proxy1 = new Proxy(target, handler1) Object.keys(proxy1) // ["message"] Object.getOwnPropertyDescriptor(proxy1, 'message'); // {value: "test", writable: true, enumerable: true, configurable: true} вроде бы defineReactive должен и к прокси добавить вьюшные прокси
https://github.com/vuejs/vue/blob/dev/src/core/observer/index.js#L120 Тут не пройдёт проверку на isPlainObject
А зачем тебе хранить прокси там?
у нас есть либа на проекте. я из нее достаю список объектов. эти объекты уже идут с прокси. я бы конечно мог их перебрать и конвернуть в простые объекты, но в этих прокси уже зашита кое-какая логика, которую не хотелось бы заново имплементить в клиентском коде
Хмм. Универсального решения в голову не приходит. Разве что так или иначе делать для Vue обычный объект и синхронизировать их.
А ты можешь повлиять на target?
в каком смысле?
прокси содаёшь ты сам на основе объекта или где-то внутри либы создаётся на внутреннем объекте?
я дергаю условный api.getObjects() и прокси создается под капотом либы
Обсуждают сегодня