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

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

  1. vue文档在声明式渲染这一节中给了我们这样的一个demo:
<div id="app">
{{ message }}
</div>
<script>
var app = new Vue({
el: '#app',
data: {
  message: 'Hello Vue!'
}
})

// 如同
const obj = {
          name:'cluo',
          age:18
      }

      function a(){
          return obj
      }
      let vuecomponent1 = a()
      let vuecomponent2 = a()
      let vuecomponent3 = a()

      vuecomponent1.name ='梅西'
      console.log(vuecomponent1)   // {name: "梅西", age: 18}
      console.log(vuecomponent2)   // {name: "梅西", age: 18}
      console.log(vuecomponent3)   // {name: "梅西", age: 18}
</script>

在这个demo中data是一个对象,通过 new Vue 创建的 Vue 实例中,我们直接把data上的message属性通过模板渲染到页面上去了。

但是在文档上Vue组件基础这一节中却告诉我们:一个组件的 data 选项必须是一个函数

  1. 为什么data必须是函数
    为什么组件中data必须是一个函数了而不是对象, 我们首先来看一下第一个声明式渲染的demo中data我们只在当前页面的挂载的div#app这个点上使用,但是对于组件有一个很明显的特性是在于它是可以被复用的,好了知道了这一点我们以一个全局注册一个组件来分析

  2. 我们先假设将data作为一个对象:
    我们前面说组件是可以被复用的,那么注册了一个组件本质上就是创建了一个组件构造器的引用,而真正当我们使用组件的时候才会去将组件实例化,

<script>
	// 创建一个组件
var Component= function() {
}
Component.prototype.data = {
  a: 1,
  b: 2
}

// 使用组件
var component1 = new Component()
var component2 = new Component()
component1.data.b = 3
component2.data.b   // 3

// 也如同

 function a() {
            return {
                name:'cluo',
                age:18
            }
        }

        let vuecomponent1 = a ()
        let vuecomponent2 = a ()
        let vuecomponent3 = a ()
        vuecomponent1.name = '梅西'
        console.log(vuecomponent1)  // {name: "梅西", age: 18}
        console.log(vuecomponent2)  // {name: "cluo", age: 18}
        console.log(vuecomponent3)  // {name: "cluo", age: 18}

</script>

我们可以发现当我们使用组件的时候,虽然data是在构造器的原型链上被创建的,但是实例化的component1和component2确是共享同样的data对象,当你修改一个属性的时候,data也会发生改变,这明显不是我们想要的效果。

当我们的data是一个函数的时候,每一个实例的data属性都是独立的,不会相互影响了。你现在知道为什么vue组件的data必须是函数了吧。这都是因为js本身的特性带来的,跟vue本身设计无关

js本身的面向对象编程也是基于原型链和构造函数,应该会注意原型链上添加一般都是一个函数方法而不会去添加一个对象了

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

学而时习之不亦说乎。

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值