Vue.js的data是要一个对象还是一个function

如题所述

在一个普通的 Vue app 中,data 是一个对象: new Vue( { data : { title : 'abc' }} ); 在 Vue 的 Component 中,data 要写成一个 function,并返回对象: Vue.component( 'component-name', Vue.extend( { data : function()
温馨提示:答案为网友推荐,仅供参考
第1个回答  2017-03-19

类型: Object | Function

限制: 组件的定义只接受 function。


都可以。但是当你在组件定义data必须使用function。

当一个组件被定义, data 必须声明为返回一个初始数据对象的函数,因为组件可能被用来创建多个实例。如果 data 仍然是一个纯粹的对象,则所有的实例将共享引用同一个数据对象!


参考资料:https://cn.vuejs.org/v2/api/#data