VUE自定义组件data引用方式的理解

自定义组件

在学习vue自定义组件时,对比定义全局vue和自定义组件时,关于data值产生疑惑:
为什么自定义组件在利用时,data变量引用方式为函数引用

Vue.component("this",{
                template:'#info',
                methods:{
                    add(){this.number++}
                },
                data:function(){
                        return{ number:0}
                    }
            })

阅读文档得知
当多个实例引用同一个对象的时候,只要其中一个实例对该对象进行操作的话,其他实例中的数据也会发生变化;而在Vue中更多的是组件复用思想,需要每个组件都有该组件自己的数据,这样组件之间才不会相互影响干扰。因此,Vue组件中的数据不能写成对象的形式,要写成函数的形式;组件中data写成一个函数,数据以函数返回值来定义,每次组件复用的时候就会返回一个新的data,这样每个组件都有属于该组件的专有空间,各个组件有各自的数据,这样就不会干扰其他组件的运行操作。

所以决定进行测试:

<div id='app'>
        <this></this>
        <this></this>
        <this></this>
    </div>

    <template id='info'>
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值