vue组件中的data为什么是一个函数

同一个组件被多次复用,会创建多个实例。这些实例用的是同一个构造函数,如果data是一个对象的话,所有的组件共享同一个对象。为了保证组件的数据独立性,要求每个组件必须通过data函数返回一个对象作为组件的状态。

一个组件被多次使用,用的是同一个构造函数。为了保证组件的不同实例的data不冲突,要求data必须是一个函数,这样组件间不会互相影响。

为了防止被公用。导致组件不独立。

主要是为了避免组件间的数据互相影响。谁new就是谁的实例,互不影响。

如果data是对象:

function VueComponent(){
}
VueComponent.prototype.$options = {
  data: {name: 'zf'}
}
let vc1 = new VueComponent();
vc1.$options.data = 'jw';
let vc2 = new VueComponent();
console.log(vc2.$options.data);//jw 拿到的是被修改之后的值

如果data是函数:

function VueComponent(){
}
VueComponent.prototype.$options = {
  data() => ({name: 'zf'})
}
let vc1 = new VueComponent();
vc1.$options.data();
let vc2 = new VueComponent();
console.log(vc2.$options.data());

为什么main.js里的new Vue({对象})里边是一个对象,因为他是根节点,只有一个。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值