组件中的数据存放问题与data为什么是函数

本文详细讲解了Vue组件中如何正确使用data函数存放数据,避免实例间数据冲突,并通过实例演示了如何封装计数器组件。强调了组件data作为函数的必要性和其在多实例场景下的优势。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.组件中的数据存放问题

组件里面不能访问vue实例的数据 

 

<template id="cpn">
  <div>
    <h2>{{message}}</h2>
    <p>内容1</p>
  </div>
</template>
<div id="app">
  <cpn></cpn>
  <cpn></cpn>
</div>

 data需要写在这个代码里面,且是返回实例对象的函数形式,不像vue示例里面一样是对象类型

 Vue.component("cpn",{})

如果写成了对象类型,报错如下: 

 

 正确写法:

  Vue.component("cpn",{
    template:"#cpn",
    data(){
      return{
        message:"abc"
      }
    }
  })

2.实现组件封装计数器

因为计数器原理简单,直接写不用函数也可以

    <button @click="counter++">+</button>
    <button @click="counter--">-</button>
<div id="app">
<cpn></cpn>
</div>

<template id="cpn">
  <div>
    <h2>当前计数:{{counter}}</h2>
    <button @click="increment">+</button>
    <button @click="decrement">-</button>
  </div>
</template>

<script src="../js/vue.js"></script>
<script>
  // 1.注册组件
  Vue.component("cpn",{
    template:"#cpn",
    data(){
      return {
        counter: 0
      }
    },
    methods:{
      increment() {
        this.counter++
      },
      decrement() {
        this.counter--
      },
    }
  })

 3.为什么组件data必须是函数而非对象

 三个cpn实例非同一个data,因为data是函数,所以避免了counter值互相影响

<div id="app">
<cpn></cpn>
  <cpn></cpn>
  <cpn></cpn>
</div>

如果想要数据同时被影响,也就是data是对象类型

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值