在vue组件中data的属性值是函数,如下所示
export default {
data() {
// data是一个函数,data: function() {}的简写
return...// data是一个对象
name: 'itclanCoder',
},
};
当一个组件被定义,data必须声明为返回一个初始数据对象的函数,因为组件可能被用来创建多个实例
也就是说,在很多页面中...,定义的组件可以复用在多个页面
如果data是一个纯碎的对象,则所有的实例将共享引用同一份data数据对象,无论在哪个组件实例中修改data,都会影响到所有的组件实例
如果data是函数,每次创建一个新实例后...Person();
p1.data.name = '川川';
console.log(p1.data.name); // 川川
console.log(p1.data.name); // 川川
挂载在原型下属性如果是一个对象...,实例化出来的对象(p1,p2)都指向的是同一份实体
原型下的属性相当于是公有的
修改一个实例对象下的属性,也会造成另一个实例属性跟着改变,这样在组件复用的时候,肯定是不行的,那么改成函数就可以了的,如下代码所示