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

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

меня есть такая проблема. Я передаю филды объекта в компонент через v-bind, и при изменении полей объекта проперти не меняются. Но если передаю целиком как проперти, то все ок.

Объект это не простой. У него для каждого филда есть свои getters/setters. Похоже они и дают это некорректное поведение.

Может кто подскажет, где посмотреть в source code как реализована работа v-bind? Что-то сам я с ходу не нашел

19 ответов

11 просмотров

Как меняешь внутри компонента?

Denis Marusevich- Автор вопроса
Grigorii K. Shartsev
Как меняешь внутри компонента?

Я скрин выше прикладывал. значение меняется. вернее так: :param="param" - тут в проперти видно что значение поменялось v-bind="param" - а тут старое значение - хотя объект один и тот же

Denis Marusevich
Я скрин выше прикладывал. значение меняется. верне...

> при изменении полей объекта проперти не меняются Где кто как меняет поля какого объекта?)

Код v-bind, если нужен, тут https://github.com/vuejs/vue/blob/dev/src/core/instance/render-helpers/bind-object-props.js

Denis Marusevich- Автор вопроса
Grigorii K. Shartsev
> при изменении полей объекта проперти не меняются...

смотри. вот накидал упрощенный варинт https://codesandbox.io/s/funny-swanson-s8fn0?file=/src/App.vue

Denis Marusevich
смотри. вот накидал упрощенный варинт https://code...

Да, так работать не будет. В obj хранится прокси к нереактивному объекту. В изменении через прокси изменяется нереактивный объект. Прокси не становится реактивным, как объект

Denis Marusevich- Автор вопроса
Grigorii K. Shartsev
Да, так работать не будет. В 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 должен и к прокси добавить вьюшные прокси

Denis Marusevich
хотя смотрю как работает реактивность в вью https:...

https://github.com/vuejs/vue/blob/dev/src/core/observer/index.js#L120 Тут не пройдёт проверку на isPlainObject

Denis Marusevich
спасибо!

А зачем тебе хранить прокси там?

Denis Marusevich- Автор вопроса
Grigorii K. Shartsev
А зачем тебе хранить прокси там?

у нас есть либа на проекте. я из нее достаю список объектов. эти объекты уже идут с прокси. я бы конечно мог их перебрать и конвернуть в простые объекты, но в этих прокси уже зашита кое-какая логика, которую не хотелось бы заново имплементить в клиентском коде

Denis Marusevich
у нас есть либа на проекте. я из нее достаю список...

Хмм. Универсального решения в голову не приходит. Разве что так или иначе делать для Vue обычный объект и синхронизировать их.

Denis Marusevich- Автор вопроса
Denis Marusevich
в каком смысле?

прокси содаёшь ты сам на основе объекта или где-то внутри либы создаётся на внутреннем объекте?

Denis Marusevich- Автор вопроса
Grigorii K. Shartsev
прокси содаёшь ты сам на основе объекта или где-то...

я дергаю условный api.getObjects() и прокси создается под капотом либы

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

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

Какой-то там пердун в 90-х решил, что есть какая-то разная типизация. Кого вообще это волнует?
КТ315
49
void terminal_scroll() { memmove(terminal_buffer, terminal_buffer + VGA_WIDTH, buffer_size - VGA_WIDTH); memset(terminal_buffer + buffer_size - VGA_WIDTH, 0, VGA_WIDTH); ...
Егор
47
Всем привет! Подскажите, пожалуйста, в чем ошибка? Настраиваю подключение к MySQL. Либы лежат рядом с exe. Все как по "учебнику"
Евгений
16
А можете как-то проверить меня по знаниям по ассемблеру?
A A
132
Здравствуйте! У меня появилась возможность купить книгу "Изучай Haskell во имя добра!". Но я где-то слышал, что эта книга устарела. Насколько это правда??
E
22
Здравствуйте! Я вот на stepic решаю задачи на хаскеле https://stepik.org/lesson/8443/step/8?unit=1578 мой код import Data.List (isInfixOf) removing :: String -> [String] ->...
E
10
Камрады, кто тесно работал с vtv, хотел уточнить. Ширина column задаётся жёстко на этапе создания дерева или можно в рантайме ее менять программно (не мышкой)?
Ed Doc
10
да ладно ... что там неочевидного ? глянуть в исх-ки датасета и/или кверика чтобы понять в каком месте и как выполняется обращения к св-вам blablaSQL - минутное дело, даже е...
Сергей
7
Здесь для arm кто-нибудь кодит ?
Nothing
52
Всем привет, у меня есть сервер принимающий входящие HTTP подключения, как проверить, что подключение было через прокси или нет, есть какие то поля в заголовках по которым мо...
DS
8
Карта сайта