Это потому, что отображаются шаблоны HTML.
Когда Vue «компилирует» ваш html, он в основном создает следующую «вычисляемую» функцию
render(createElement) { /* `createElement` is also known as `h` in the Vue world */
return createElement('my-comp', {
props: {
myProp: { my: { literal: { object: { with: { nested: { field: ‘not reactive’ }}}}}},
},
);
},
Поскольку полный поток значения myProp
никогда не проходит через функцию данных,ни через возвращаемый результат вычисленной нормальной функции, она никогда не будет помечена для реактивности.
Хотя может показаться странным, что Vue отмечает возвращаемый результат всех «вычисленных» функций, ожидайтеспециальная функция рендеринга реагирует, это действительно имеет смысл, если взглянуть на идею дизайна Vue, а именно на вход и выход.Эта не маркировка реактивности дает нам повышение производительности по сравнению с маркировкой реактивности.
Если вам все еще требуется, чтобы она была реактивной (и, следовательно, вы хотите пойти вразрез с основными принципами Vue (и, таким образом, сделать свое приложение)труднее понять)), вы можете сделать это, сохранив значение в разделе данных вашего компонента или вернув его из вычисляемого свойства.