Composition Api 与 Options Api 有什么区别?

Vue 3.0采用的Composition API与Vue 2.x使用的Options API在编写Vue组件时有一些区别。

区别:

  1. 组织代码的方式不同:

    • Options API:按照选项进行组织,将数据、计算属性、方法等声明在一个对象中。
    • Composition API:按照逻辑功能进行组织,将相关逻辑代码放在一个函数中。
  2. 数据和方法的访问方式不同:

    • Options API:通过this关键字访问数据和方法。
    • Composition API:通过引入具体的函数进行数据和方法的处理。

作用:

  • Options API:提供了一种简洁明了的方式来定义和组织组件的选项(data、methods、computed等),适合于小型应用或简单的组件。
  • Composition API:通过将逻辑相关的代码封装在函数中,提供更灵活的组织方式,使得代码复用、组织和测试更加方便,特别适合于大型应用或复杂的组件。

使用:

html 复制代码
<template>
  <div>
    <p>{{ message }}</p>
    <button @click="changeMessage">Change Message</button>
  </div>
</template>

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

2.Composition API 示例:

html 复制代码
<template>
  <div>
    <p>{{ message }}</p>
    <button @click="changeMessage">Change Message</button>
  </div>
</template>

<script>
import { reactive } from 'vue';

export default {
  setup() {
    const state = reactive({
      message: 'Hello Vue'
    });

    const changeMessage = () => {
      state.message = 'New Message';
    };

    return {
      ...state,
      changeMessage
    };
  }
};
</script>

在Composition API示例中,使用reactive函数将数据变为响应式,并利用setup()函数组织逻辑代码。通过返回一个包含数据和方法的对象,让它们可以在模板中被访问。

通过Composition API,我们可以将相关的代码逻辑进行封装并复用,使得代码更加清晰、可维护性更强。此外,Composition API还提供了其他一些函数,如computedwatch等,用于处理计算属性和监听数据变化等操作。

相关推荐
爱勇宝13 小时前
大多数人不是在使用 AI 赚钱,而是在帮 AI 公司赚钱
前端·后端·程序员
冬奇Lab14 小时前
每日一个开源项目(第143篇):page-agent - 纯 JS 的网页 GUI Agent,无需截图、无需插件、无需后端
前端·人工智能·agent
To_OC15 小时前
LC 994 腐烂的橘子:人人都说是 BFS 入门题,我却写了三遍才过
javascript·算法·leetcode
IT_陈寒18 小时前
React的这个渲染问题连官方文档都没说清楚
前端·人工智能·后端
追逐时光者19 小时前
别再满网找零散工具了,腾讯 QQ 浏览器这个“帮小忙”工具箱真能省时间
前端·后端
如果超人不会飞19 小时前
脉络清晰的业务演进:TinyVue Timeline 时间线组件全方位实战指南
vue.js
如果超人不会飞20 小时前
从扁平到立体:掌握 TinyVue Grid 树形表格的高级实战指南
vue.js
To_OC21 小时前
LC 200 岛屿数量:经典 DFS 入门题,我第一次写居然连方向都搞错了
javascript·算法·leetcode
Asmewill21 小时前
grep&curl命令学习笔记
前端
stringwu1 天前
Flutter 开发必备:MVI 架构的高效实现指南
前端·flutter