Home> Web Front-end> Vue.js> body text

Super detailed! Graphics and text explain Vue3's combined API!

藏色散人
Release: 2022-08-09 09:30:03
forward
3002 people have browsed it

Composition API

  • Composition API (Composition API) is a very valuable API update for vue3 for our developers. Let’s not focus on the specific syntax first. It has a big perception

1. composition vs options

  • #options The vue application developed by the API is shown on the left, and its characteristic is understanding Easy, because each option has a fixed writing position. For example, responsive data is written in the data selection, operation methods are written in the methods configuration item, etc. After the application becomes large, I believe everyone will encounter the dilemma of looking up and down for the code.
  • The vue application developed by composition API is shown on the right. Its characteristic is that everything related to specific functions is put together and maintained, such as responsive data related to function A, methods of operating data, etc. Together, no matter how big the application is, you can quickly read and locate all relevant codes for a certain function, which is easy to maintain. If the function is complex and the amount of code is large, we can also perform logical split processing [Recommended:vue video tutorial
    Super detailed! Graphics and text explain Vue3s combined API!
    Super detailed! Graphics and text explain Vue3s combined API!
    Special note:
  • Optional API and combined API styles coexist Relationships are not either/or

  • Scenarios that require a large number of logical combinations can be enhanced using the compition API

2. Case comparison

Above we briefly learned about the new API form brought by vue3 through the diagram. Next, we use a specific small case to have a more in-depth experience of the comparison of the development models under the two APIs. Let’s first Ignore the grammatical details for the time being and focus only on the code writing form

2.1 Understanding the requirements

Super detailed! Graphics and text explain Vue3s combined API!
Two independent functions:

  • Control the display and hiding of p by clicking the button

  • Control the change of font color in p by clicking the button

2.2 vue2.x option Api version

 
Copy after login

2.3 vue3.0 composition api version

 
Copy after login

2.4 composition api version optimization

There may be doubts here, so now we are All data and behaviors related to functions are maintained together. If the application is large and has many functions, won't the setup function become very large? Wouldn't it become more difficult to maintain? Next, let's dismantle the huge setup function

Copy after login

Above, we separated the two functionally related codes by defining functional functions. into an independent small function, and then combine the two small functional functions in the setUp function. In this way, we can not only make the setup function refreshing, but also facilitate the maintenance of quick positioning functions

At this point we have not paid attention to the details of the api, but just realized the benefits that the combined api has given us. Next we will go into the details of the api and see how to use the new api↓

3. setup entry function

  1. The setup function is a new component option, which serves as the starting point (entry) of the combined API in the component.
  2. This cannot be used in setup, this Pointing to undefined
  3. The setup function will only be executed once when the component is initialized
  4. The setup function is executed before the beforeCreate life cycle hook is executed
export default { setup () { console.log('setup执行了') console.log(this) }, beforeCreate() { console.log('beforeCreate执行了') console.log(this) }}
Copy after login

4. Responsive system API

4.1 reactive function

  • Function: reactive is a function that receives an ordinary object, converts the object data into a responsive object and returns

Use steps

  • Import the reactive function from the vue framework

  • Call the reactive function in the setup function and Pass the object data in

  • In the setup function, return the return value after the reactive function is called in the form of an object

Code implementation

 
Copy after login

4.2 ref function

  • Function: ref is a function that accepts a simple or complex type and returns a responsive and variable ref object

Use steps

  • Export the ref function from the vue framework

  • Call in the setup function ref function and pass in data (simple type or complex type)

  • In the setup function, return the return value after calling the ref function in the form of an object

  • Note: When using the ref result in the setup function, you need to access it through .value. When using it in the template, you do not need to add .value

 
Copy after login

Summary instructions:

  • The ref function can receive a simple type value and return a changeable ref responsive object, thereby making up for the problem that the reactive function does not support simple types

  • reactive和ref函数都可以提供响应式数据的转换,具体什么时候需要使用哪个API社区还没有最佳实践,大家暂时可以使用自己熟练的API进行转换

  • 推荐一种写法:只有我们明确知道要转换的对象内部的字段名称我们才使用reactive,否则就一律使用ref,从而降低在语法选择上的心智负担

4.3 toRefs 函数

  • 场景: 经过reactive函数处理之后返回的对象,如果给这个对象解构或者展开,会让数据丢失响应式的能力,为了解决这个问题需要引入toRefs函数,使用 toRefs函数 可以保证该对象展开的每个属性都是响应式的

4.3.1 问题复现

还是之前的案例,如果我们想在模板中省略到state,直接书写name和age,你可能会想到,那我在return出去的时候把state中的属性解构出来不就好了

修改前

 
Copy after login

解构修改后

 
Copy after login
  • 点击改值按钮,发现视图已经不发生变化了,这就是我们所说的,如果解构reactive的返回值,将破坏调用响应式特性,就需要我们使用toRefs方法进行处理了

4.3.2 toRefs包裹处理

 
Copy after login

4.4 computed

  • 在setup函数中使用计算属性函数

作用:根据现有响应式数据经过一定的计算得到全新的数据

使用步骤

  • 从vue框架中导入computed 函数

  • 在setup函数中执行computed函数,并传入一个函数,在函数中定义计算公式

  • 把computed函数调用完的执行结果放到setup的return值对象中

Copy after login

4.5 watch 侦听器

  • 在setup函数中侦听器的使用

作用:基于响应式数据的变化执行回调逻辑,和vue2中的watch的功能完全一致

  • 普通监听

  • 立即执行

  • 深度监听

使用步骤

  • 从vue框架中导入watch函数

  • 在setup函数中执行watch函数开启对响应式数据的监听

  • watch函数接收三个常规参数

    1. 第一个参数为函数,返回你要监听变化的响应式数据
    2. 第二个参数为响应式数据变化之后要执行的回调函数
    3. 第三个参数为一个对象,在里面配置是否开启立刻执行或者深度监听

4.5.1 普通监听

Copy after login

4.5.2 开启立刻执行

watch的效果默认状态下,只有监听的数据发生变化才会执行回调,如果你需要在一上来的时候就立刻执行一次,需要配置一下immediate属性

Copy after login

4.5.3 开启深度监听

当我们监听的数据是一个对象的时候,默认状态下,对象内部的属性发生变化是不会引起回调函数执行的,如果想让对象下面所有属性都能得到监听,需要开启deep配置

Copy after login

4.5.4 更好的做法

使用watch的时候,尽量详细的表明你到底要监听哪个属性,避免使用deep引起的性能问题,比如我仅仅只是想在state对象的age属性变化的时候执行回调,可以这么写

Copy after login

5. 生命周期函数

使用步骤

  • 先从vue中导入以on打头的生命周期钩子函数

  • 在setup函数中调用生命周期函数并传入回调函数

  • 生命周期钩子函数可以调用多次

 
Copy after login
选项式API 组合式API
beforeCreate 不需要(直接写到setup函数中)
created 不需要(直接写到setup函数中)
beforeMount onBeforeMount
mounted onMounted
beforeUpdate onBeforeUpdate
updated onUpdated
beforeDestroyed onBeforeUnmount
destroyed onUnmounted

6. 父子通信

在vue3的组合式API中,父传子的基础套路完全一样,基础思想依旧为:父传子是通过prop进行传入,子传父通过调用自定义事件完成

实现步骤

  • setup函数提供俩个参数,第一个参数为props,第二个参数为一个对象context

  • props为一个对象,内部包含了父组件传递过来的所有prop数据,context对象包含了attrs,slots, emit属性,其中的emit可以触发自定义事件的执行从而完成子传父

代码落地
app.vue

Copy after login

components/son.vue

 
Copy after login

7. provide 和 inject

通常我们使用props进行父子之间的数据传递,但是如果组件嵌套层级较深,一层一层往下传递将会变的非常繁琐,有没有一种手段可以把这个过程简化一下呢,有的,就是我们马上要学习的provide 和 inject,它们配合起来可以方便的完成跨层传递数据

Super detailed! Graphics and text explain Vue3s combined API!

7.1 基础使用

  • 在setup函数中使用provide和inject的基础用法

来个需求: 爷组件中有一份数据 传递给孙组件直接使用
Super detailed! Graphics and text explain Vue3s combined API!

实现步骤:

  • 顶层组件在setup方法中使用provide函数提供数据

  • 任何底层组件在setup方法中使用inject函数获取数据

代码落地
爷爷组件 - app.vue

Copy after login

孙组件 - components/Son.vue

Copy after login

事实上,只要是后代组件,都可以方便的获取顶层组件提供的数据

7.2 传递响应式数据

provide默认情况下传递的数据不是响应式的,也就是如果对provide提供的数据进行修改,并不能响应式的影响到底层组件使用数据的地方,如果想要传递响应数据也非常简单,只需要将传递的数据使用ref或者reactive生成即可

  • 通过provide/inject传递响应式数据
    app.vue
Copy after login

8. 模板中 ref 的使用

在模板中使用ref,我们都很清楚,它一般有三种使用场景

  • ref + 普通dom标签 获取真实dom对象

  • ref + 组件标签 获取组件实例对象

  • ref + v-for 获取由dom对象(实例对象)组成的数组 (不经常使用)

  • 在setup函数中使用ref获取真实dom获取组件实例的方法

实现步骤

  • 使用ref函数传入null创建 ref对象 =>const hRef = ref(null)

  • 模板中通过定义ref属性等于1中创建的ref对象名称建立关联 =>

  • 使用 =>hRef.value

代码落地
components/RefComponent.vue

Copy after login

app.vue

Copy after login

9. 来个案例吧 - Todos

核心功能

  • 渲染列表数据 v-for

  • 点击删除当前列表 splice + index

  • 回车添加新项目 @keyup.enter=“addTodo” list.unshift

  • 选择状态切换 v-model

  • 多选和取消多选 计算属性的set和get

  • 未完成任务数量统计 computed

Copy after login

The above is the detailed content of Super detailed! Graphics and text explain Vue3's combined API!. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
vue
source:csdn.net
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn