vue中data定义数字类型_为什么 vue 组件中的 data 是函数而不是对象

在vue组件中data的属性值是函数,如下所示

export default {

data() {

// data是一个函数,data: function() {}的简写

return {

// 页面要初始化的数据

name: 'itclanCoder',

};

},

};

而非:如下所示

export default {

data: {

// data是一个对象

name: 'itclanCoder',

},

};

当一个组件被定义,data必须声明为返回一个初始数据对象的函数,因为组件可能被用来创建多个实例

也就是说,在很多页面中,定义的组件可以复用在多个页面

如果data是一个纯碎的对象,则所有的实例将共享引用同一份data数据对象,无论在哪个组件实例中修改data,都会影响到所有的组件实例

如果data是函数,每次创建一个新实例后,调用data函数,从而返回初始数据的一个全新副本数据对象

这样每复用一次组件,会返回一份新的data数据,类似于给每个组件实例创建一个私有的数据空间,让各个组件的实例各自独立,互不影响,保持低耦合

可以看下面一段代码

// 声明构造器函数

function Person() {}

Person.prototype.data = {

// 原型下挂载一对象,并有name属性

name: 'itclanCoder',

};

var p1 = new Person();

var p2 = new Person();

p1.data.name = '川川';

console.log(p1.data.name); // 川川

console.log(p2.data.name); // 川川

挂载在原型下属性如果是一个对象,实例化出来的对象(p1,p2)都指向的是同一份实体

原型下的属性相当于是公有的

修改一个实例对象下的属性,也会造成另一个实例属性跟着改变,这样在组件复用的时候,肯定是不行的,那么改成函数就可以了的,如下代码所示

function Person() {

this.data = this.data();

}

Person.prototype.data = function() {

return {

name: 'itclanCoder',

};

};

var p1 = new Person();

var p2 = new Person();

p1.data.name = '随笔川迹'; // 如果是函数的形式去定义属性,它是有自定的作用域的,在修改的时候不会影响到别人

console.log(p1.data.name); // 随笔川迹

console.log(p2.data.name); // itclanCoder

你可能感兴趣的:(vue中data定义数字类型)