vue3 composition(组合式)API 是什么?我为什么要使用它?

文章讲述了Vue.js中从optionsAPI向组合式API的转变,如何通过`setup`函数和`function`组件来组织代码,提高代码结构的清晰度和复用性,减少大型`setup`函数的担忧。
摘要由CSDN通过智能技术生成

}

}

const app = Vue.createApp(component)

app.mount(‘#app’)

这是标准的 options API 格式的代码,如果我们要用颜色对其所涉及到的业务进行划分,那么我们将得到这样的一个图形。

此处 :

紫色区域姓名 相关的代码

绿色区域年龄 相关的代码

而假如我们的代码更加的复杂,比如同时涉及到 props、data、methods、computed、watch 等其他属性的时候,那么你的代码结构图将会变成下面这个样子

在这里插入图片描述

而这样一套代码的组件会变得非常难以阅读,因为我们很难搞清楚 哪些代码是和哪些代码在一起使用的

而这个就是 组合式API 所尝试进行解决的第一个问题。我们来看下面这套代码。

const component = {

setup() {

const people = {

name: ‘LGD_Sunday’,

age: 18

}

// 处理 name 相关的业务

const name = Vue.ref(‘’)

const getName = () => {

name.value = people.name;

}

// 处理 age 相关的业务

const age = Vue.ref(‘’)

const getAge = () => {

age.value = people.age;

}

return {

name,

getName,

age,

getAge

}

}

}

根据上面的代码,那么我们将会得到这样的一套代码视图

此时我们已经将相关联的代码保持在了一起,那么我们的代码将更具有可读性,因此也更具有可维护性

但是?


但是我相信很多有经验的开发者看到这样的一套代码的时候,肯定会有一个疑惑。

那就是:如果我们的代码将要通过这样的一种方式被组装的话,那么是不是意味着我们将会有一个巨大的 setup 函数,这个函数将会用来描述组件中所有的 data、methods、computed、watch

不不不,当然不会出现这种情况。

我们可以通过 功能分组 的方式来对以上的代码进行处理,我们来看下面的这段代码。

const component = {

setup() {

const people = {

name: ‘LGD_Sunday’,

age: 18

}

return {

…useName(people),

…useAge(people)

}

},

components: {

componentB

}

}

// 处理 name 相关的业务

function useName(people) {

const name = Vue.ref(‘’)

const getName = () => {

name.value = people.name;

}

return {

name,

getName

}

}

// 处理 age 相关的业务

function useAge(people) {

const age = Vue.ref(‘’)

const getAge = () => {

age.value = people.age;

}

return {

age,

getAge

}

}

在这里我们额外创建两个方法,分别处理 nameage 相关的事情。然后通过展开运算符setup 函数中返回了相关的变量和方法。

截止到现在,我们的代码已经可以根据 各自的功能模块来进行了完美的切割,从而使我们的代码拥有了更好的可读性。

同时这样的一套代码逻辑也可以在 不同的组件中进行复用

逻辑复用的问题


我们来看下面这段代码:

// 此时假如我们有了另外一个组件,我们依然可以复用这两个方法

const componentB = {

setup() {

const people = {

name: ‘迪丽热巴’,

age: 19

}

return {

…useName(people),

…useAge(people)

}

},

template: `

{{name}}

<button @click=“getName”>姓名

{{age}}

<button @click=“getAge”>年龄

`

}

// Composition API 功能分组实现方案

const component = {

setup() {

const people = {

name: ‘LGD_Sunday’,

age: 18

}

return {

…useName(people),

…useAge(people)

}

},

components: {

componentB

}

}

// 处理 name 相关的业务

function useName(people) {

const name = Vue.ref(‘’)

const getName = () => {

name.value = people.name;

}

return {

name,

getName

}

}

// 处理 age 相关的业务

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
img

最后

在面试前我花了三个月时间刷了很多大厂面试题,最近做了一个整理并分类,主要内容包括html,css,JavaScript,ES6,计算机网络,浏览器,工程化,模块化,Node.js,框架,数据结构,性能优化,项目等等。

包含了腾讯、字节跳动、小米、阿里、滴滴、美团、58、拼多多、360、新浪、搜狐等一线互联网公司面试被问到的题目,涵盖了初中级前端技术点。

  • HTML5新特性,语义化

  • 浏览器的标准模式和怪异模式

  • xhtml和html的区别

  • 使用data-的好处

  • meta标签

  • canvas

  • HTML废弃的标签

  • IE6 bug,和一些定位写法

  • css js放置位置和原因

  • 什么是渐进式渲染

  • html模板语言

  • meta viewport原理

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
img

bug,和一些定位写法

  • css js放置位置和原因

  • 什么是渐进式渲染

  • html模板语言

  • meta viewport原理

一个人可以走的很快,但一群人才能走的更远。不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎扫码加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
[外链图片转存中…(img-8YAOfi0z-1712868434374)]

  • 7
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue3中的Composition API是一种新的API,它允许开发者通过逻辑组合的方式来组织他们的Vue组件。与之前的Options API不同,Composition API允许开发者将逻辑代码进行组合,而不是将它们分散在各种生命周期和方法中。这样做可以使代码更加清晰,易于维护和重用。 Composition API的优势包括: 1. 更好的代码组织:Composition API允许开发者按照功能将代码进行组合,使代码更加清晰、易于维护和重用。 2. 更好的类型推断:Composition API可以更好地与TypeScript集成,这意味着开发者可以获得更好的类型推断和代码提示。 3. 更好的逻辑复用:Composition API允许开发者将逻辑代码进行组合并封装成可复用的函数,这样可以更好地复用逻辑代码。 Composition API的用法包括: 1. 使用setup函数:在Vue3中,每个组件都必须有一个setup函数,它是使用Composition API的入口点。 2. 使用ref和reactive:ref和reactive是Composition API中最常用的两个函数。ref用于创建响应式的基本数据类型,而reactive用于创建响应式的对象和数组。 3. 使用computed和watch:computed和watch是Composition API中用于响应式计算和监听数据变化的函数。 4. 使用生命周期钩子函数:在Composition API中,生命周期钩子函数也可以通过onXXX函数来定义,例如beforeMount可以定义为onBeforeMount函数。 总的来说,Composition APIVue3中一个非常有用的新特性,它可以帮助开发者更好地组织和重用代码,提高代码的可读性和可维护性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值