vue3中reactive和ref函数及对比

reactive和ref函数

1. reactive

接受对象类型数据的参数传入并返回一个响应式的对象

javascript 复制代码
<script setup>
 // 导入
 import { reactive } from 'vue'
 // 执行函数 传入参数 变量接收
 const state = reactive({
   msg:'this is msg'
 })
 const setSate = ()=>{
   // 修改数据更新视图
   state.msg = 'this is new msg'//不需要.value
 }
</script>

<template>
  {{ state.msg }}
  <button @click="setState">change msg</button>
</template>

2. ref

接收简单类型或者对象类型的数据传入并返回一个响应式的对象

javascript 复制代码
<script setup>
 // 导入
 import { ref } from 'vue'
 // 执行函数 传入参数 变量接收
 const count = ref(0)
 const setCount = ()=>{
   // 修改数据更新视图必须加上.value
   count.value++
 }
</script>

<template>
  <button @click="setCount">{{count}}</button>
</template>

注意:

  • ref函数创建响应式数据,返回值是一个对象

  • 模版中使用ref数据,省略.value,js代码中不能省略(特殊:js中watch监听可以省)

3、reactive 对比 ref

  1. 都是用来生成响应式数据

  2. 不同点:

    1. reactive不能处理简单类型的数据,只支持引用数据类型,ref支持基本和引用数据类型

    2. ref通过.value获取数据,reactive不需要.value

    3. ref创建响应式引用数据类型低层依赖reactive

相关推荐
书院门前细致的苹果4 分钟前
JVM 全面详解:深入理解 Java 的核心运行机制
java·jvm
上官浩仁18 分钟前
springboot excel 表格入门与实战
java·spring boot·excel
Hello.Reader1 小时前
从零到一上手 Protocol Buffers用 C# 打造可演进的通讯录
java·linux·c#
gnip1 小时前
链式调用和延迟执行
前端·javascript
树码小子1 小时前
Java网络初识(4):网络数据通信的基本流程 -- 封装
java·网络
SoaringHeart2 小时前
Flutter组件封装:页面点击事件拦截
前端·flutter
杨天天.2 小时前
小程序原生实现音频播放器,下一首上一首切换,拖动进度条等功能
前端·javascript·小程序·音视频
稻草人想看远方2 小时前
GC垃圾回收
java·开发语言·jvm
Dragon Wu2 小时前
React state在setInterval里未获取最新值的问题
前端·javascript·react.js·前端框架
Jinuss2 小时前
Vue3源码reactivity响应式篇之watch实现
前端·vue3