vue3中新增的组合式API:ref、reactive、toRefs、computed、watch、provide/inject、$ref

本文主要是介绍vue3中新增的组合式API:ref、reactive、toRefs、computed、watch、provide/inject、$ref,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在 Vue3 中,组合式 API 是一种新的编程模式,它允许你更灵活地组织和重用代码。组合式 API 主要包括以下几个部分:

  1. ref:用于创建响应式数据。
  2. reactive:用于创建一个响应式对象。
  3. toRefs:将一个响应式对象转换为普通对象。
  4. computed:用于创建计算属性。
  5. watch:用于监听数据变化。
  6. provide/inject:用于跨组件通信。

ref

类似于vue2中的data(){return{}}

在 Vue3 中,ref 用于创建响应式数据。以下是一个简单的 Vue3 代码示例:

<template><div><h1>{{ count }}</h1><button @click="increment">增加</button></div>
</template><script setup>
import { ref } from 'vue';
//定义简单变量const count = ref(0);function increment() {count.value++;}
// 定义复杂变量
const arr = ref([0,1,2,1,3,4])
const obj = ref({
name:"Tom"
})
</script>

reactive

专门给object赋值的,reactive只能用于复杂变量,不能用于简单变量

在 Vue3 中,reactive 用于创建一个响应式对象。以下是一个简单的 Vue3 代码示例:

<template><div><input v-model="message" placeholder="请输入内容" /><p>{{ message }}</p></div>
</template><script setup>
import { reactive } from 'vue';const state = reactive({message: '',});</script>

在这个示例中,我们使用 reactive 创建了一个名为 state 的响应式对象,并将其返回。然后,在模板中使用 v-model 指令将输入框的值与 state.message 进行双向绑定。这样,当输入框的值发生变化时,state.message 也会相应地更新。

toRefs

在 Vue3 中,toRefs 用于将一个响应式对象转换为一个普通对象,其中每个属性都是一个 ref。以下是一个简单的 Vue3 代码示例:

<template><div><input v-model="message" placeholder="请输入内容" /><p>{{ message }}</p></div>
</template><script setup>
import { reactive, toRefs } from 'vue';const state = reactive({message: '',});const stateRefs = toRefs(state);</script>

在这个示例中,我们首先使用 reactive 创建了一个名为 state 的响应式对象。然后,我们使用 toRefsstate 转换为一个普通对象 stateRefs,其中每个属性都是一个 ref。最后,我们将 stateRefs 解构并返回,以便在模板中使用。

computed

在 Vue3 中,可以使用 computed 函数来创建多个计算属性。以下是一个简单的 Vue3 代码示例:

<template><div><input v-model="message" placeholder="请输入内容" /><p>{{ reversedMessage }}</p><p>{{ uppercaseMessage }}</p></div>
</template><script  setup>
import { ref, computed } from 'vue';const message = ref('Hello Vue3!');const reversedMessage = computed(() => {return message.value.split('').reverse().join('');});const uppercaseMessage = computed(() => {return message.value.toUpperCase();});</script>

在这个示例中,我们创建了两个计算属性:reversedMessageuppercaseMessage。它们分别返回 message 的反转字符串和大写字符串。我们将这两个计算属性解构并返回,以便在模板中使用。

watch

在 Vue3 中,watch 用于监听数据的变化。以下是一个简单的 Vue3 代码示例,包括简单监听、深度监听和监听某一个 object 中的变量,以及同时监听多个简单变量和多个复杂变量:

<template><div><input v-model="message" placeholder="请输入内容" /><p>{{ reversedMessage }}</p><p>{{ uppercaseMessage }}</p><p>{{ person.name }}</p></div>
</template><script  setup>
import { ref, watch } from 'vue';const message = ref('Hello Vue3!');const person = ref({ name: 'John', age: 30 });// 简单监听watch(message, (newValue, oldValue) => {console.log('message changed:', newValue, oldValue);});// 深度监听watch(() => person.value, (newValue, oldValue) => {console.log('person changed:', newValue, oldValue);}, { deep: true });// 监听某一个 object 中的变量const personName = computed(() => person.value.name);watch(personName, (newValue, oldValue) => {console.log('person.name changed:', newValue, oldValue);});// 同时监听多个简单变量和多个复杂变量const numbers = ref([1, 2, 3]);const complexObjects = ref([{ a: 1 }, { b: 2 }]);watch([message, numbers, complexObjects], () => {console.log('message, numbers or complexObjects changed');});</script>

在这个示例中,我们创建了一个简单的 message 变量,并使用 watch 函数进行监听。我们还创建了一个 person 对象,并使用 watch 函数进行深度监听。接下来,我们创建了一个计算属性 personName,并使用 watch 函数监听它的变化。最后,我们创建了两个数组 numberscomplexObjects,并使用 watch 函数同时监听它们的变化。

父子组件的传值

vue3中 使用defineProps 和 defineEmits 进行父子组件的传值:

父传子

子组件:

<template><div>这是子组件:{{fatherName}}</div>
</template><script  setup>
const props= defineProps({
fatherName:String
})</script>

父组件:

<template><div>这是父组件:和vue一样的传递方式<child :fatherName='fatherName'></child></div>
</template><script  setup>
import child  from "子组件地址"
import {ref} from "vue"
const fatherName=ref("父组件变量")</script>

子传父

子组件:

<template><div>这是子组件:{{fatherName}}</div>
</template><script  setup>
const props= defineEmits(['setChildname'])
const sendtoFather=()=>{
emit('setChildname',"向父组件传值")
}
</script>

父组件:

<template><div>这是父组件:<child @setChildname='getChildname'></child></div>
</template><script  setup>
import child  from "子组件地址"
count getChildname=(data)=>{
data就是来自子组件传递的参数
}</script>

顶级向底级传参: provide/inject:用于跨组件通信。

vue2中是使用$evenbus这样的全局变量来传递变量,其中使用的就是$emit $on来传递数据,但是vue3中没有$on这个方法

传递值: provide

<template></template><script  setup>
import {provide} from "vue"
provide('setname',"这是传递的参数")
</script>

接收值:inject

<template><div>这是接收的值:{{getName}}</div>
</template><script  setup>
import {inject} from "vue"
const getName=inject('setname')
</script>

注意:provide/inject:用于跨组件通信只是用于顶级向底级传参,就是从上到下的传递

$ref

父组件通过$ref 调用子组件的方法,并传值

vue3中 子组件还可以使用defineExpose来暴露方法和变量来让父组件获取到子组件的数据
子组件:

<template><div>这是子组件:</div>
</template><script  setup>
import {ref} from "vue"const name= ref('子组件名字')const childFun = (data)=>{子组件的方法
}
defineExpose({
name,
chiildFun
})
</script>

父组件:

<template><div>这是父组件:<child ref='child'></child>
子组件的name:{{childObj}}</div>
</template><script  setup>
import child  from "子组件地址"
import {ref} from "vue"const child= ref(null)const dochiildFun=()=>{child.value.chiildFun({id:1,age:30})}
</script>

这篇关于vue3中新增的组合式API:ref、reactive、toRefs、computed、watch、provide/inject、$ref的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/544876

相关文章

CSS3 布局样式及其应用举例

《CSS3布局样式及其应用举例》CSS3的布局特性为前端开发者提供了无限可能,无论是Flexbox的一维布局还是Grid的二维布局,它们都能够帮助开发者以更清晰、简洁的方式实现复杂的网页布局,本文给... 目录深入探讨 css3 布局样式及其应用引言一、CSS布局的历史与发展1.1 早期布局的局限性1.2

使用animation.css库快速实现CSS3旋转动画效果

《使用animation.css库快速实现CSS3旋转动画效果》随着Web技术的不断发展,动画效果已经成为了网页设计中不可或缺的一部分,本文将深入探讨animation.css的工作原理,如何使用以及... 目录1. css3动画技术简介2. animation.css库介绍2.1 animation.cs

CSS引入方式和选择符的讲解和运用小结

《CSS引入方式和选择符的讲解和运用小结》CSS即层叠样式表,是一种用于描述网页文档(如HTML或XML)外观和格式的样式表语言,它主要用于将网页内容的呈现(外观)和结构(内容)分离,从而实现... 目录一、前言二、css 是什么三、CSS 引入方式1、行内样式2、内部样式表3、链入外部样式表四、CSS 选

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

python通过curl实现访问deepseek的API

《python通过curl实现访问deepseek的API》这篇文章主要为大家详细介绍了python如何通过curl实现访问deepseek的API,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编... API申请和充值下面是deepeek的API网站https://platform.deepsee

Nginx部署React项目时重定向循环问题的解决方案

《Nginx部署React项目时重定向循环问题的解决方案》Nginx在处理React项目请求时出现重定向循环,通常是由于`try_files`配置错误或`root`路径配置不当导致的,本文给大家详细介... 目录问题原因1. try_files 配置错误2. root 路径错误解决方法1. 检查 try_f

Java对接Dify API接口的完整流程

《Java对接DifyAPI接口的完整流程》Dify是一款AI应用开发平台,提供多种自然语言处理能力,通过调用Dify开放API,开发者可以快速集成智能对话、文本生成等功能到自己的Java应用中,本... 目录Java对接Dify API接口完整指南一、Dify API简介二、准备工作三、基础对接实现1.

在React聊天应用中实现图片上传功能

《在React聊天应用中实现图片上传功能》在现代聊天应用中,除了文字和表情,图片分享也是一个重要的功能,本文将详细介绍如何在基于React的聊天应用中实现图片上传和预览功能,感兴趣的小伙伴跟着小编一起... 目录技术栈实现步骤1. 消息组件改造2. 图片预览组件3. 聊天输入组件改造功能特点使用说明注意事项

一文详解如何在Vue3中封装API请求

《一文详解如何在Vue3中封装API请求》在现代前端开发中,API请求是不可避免的一部分,尤其是与后端交互时,下面我们来看看如何在Vue3项目中封装API请求,让你在实现功能时更加高效吧... 目录为什么要封装API请求1. vue 3项目结构2. 安装axIOS3. 创建API封装模块4. 封装API请求

全解析CSS Grid 的 auto-fill 和 auto-fit 内容自适应

《全解析CSSGrid的auto-fill和auto-fit内容自适应》:本文主要介绍了全解析CSSGrid的auto-fill和auto-fit内容自适应的相关资料,详细内容请阅读本文,希望能对你有所帮助... css  Grid 的 auto-fill 和 auto-fit/* 父元素 */.gri