在 Vue 3.0 中,data 选项的使用方式与 Vue 2.x 有一些变化。Vue 3.0 引入了 data 函数的概念,以确保每个组件实例都有独立的数据副本,从而避免在组件之间共享数据引发的问题。

以下是在 Vue 3.0 中使用 data 选项的示例:
<template>
  <div>
    <p>{{ message }}</p>
    <button @click="changeMessage">Change Message</button>
  </div>
</template>

<script>
export default {
  data() {
    return {
      message: 'Hello from Vue 3.0'
    };
  },
  methods: {
    changeMessage() {
      this.message = 'Message changed!';
    }
  }
};
</script>

在上述示例中,data 不再是一个普通的对象,而是一个返回对象的函数。这确保每个组件实例都有自己的数据副本,防止在组件之间共享数据时产生的问题。这个函数返回的对象中的属性就是组件的数据。

注意,在 Vue 3.0 中,不再支持直接在 data 中定义非响应式的普通对象,因为 Vue 3.0 引入了更严格的响应式系统。如果需要定义非响应式的属性,可以将其定义在 setup 函数中,或者使用 ref 或 reactive 进行处理。
<script>
import { ref } from 'vue';

export default {
  setup() {
    const nonReactiveData = ref('Non-reactive Data');

    // ...

    return {
      nonReactiveData
    };
  }
};
</script>

在 setup 函数中,你可以使用 ref 创建一个非响应式的数据,这样就不会受到 Vue 3.0 响应式系统的影响。需要注意的是,setup 函数是 Vue 3.0 中的 Composition API 的一部分,用于替代 Vue 2.x 中的选项 API。


转载请注明出处:http://www.pingtaimeng.com/article/detail/543/Vue 3.0