当前位置: 首页 > news >正文

#Vue3篇:响应式工具ref()、toRef()、 toRefs()、reactive()的用法和区别

ref()

定义: ref()接收一个普通的Javascript值作为参数,将其转换为响应式对象(ref对象)。
ref对象有一个.value属性,用于获取和修改之。
参数1: 一个普通的Javascript值作为参数

import { ref } from 'vue'
const count = ref(0)
console.log(count.value) // 0
count.value++ // 1

参数2: 一个工厂函数,用于创建延迟计算的响应式对象。

import { ref } from 'vue'
const name = ref(() => {console.log('计算 name')return 'Vue 3'
})
console.log(name.value) // 计算 name, Vue 3

返回: 响应式对象

toRef()

定义: 将一个响应式对象的属性转换为一个单独的ref对象。
参数:第一个参数,响应式对象;第二个参数,响应式对象的某一属性。
作用:转换后的ref对象与原对象属性具有相同的响应式行为。当修改ref对象时,原对象的属性也会同时更新。

import { reactive, toRef } from 'vue'const user = reactive({name: 'Tom',age: 20
})const ageRef = toRef(user, 'age')console.log(ageRef.value) // 20
ageRef.value++console.log(user.age) // 21

toRefs()

定义: 将一个响应式对象转换成普通Javascript对象,这个普通对象中的所有属性都是ref对象。
参数:响应式对象
作用: 当修改ref对象时,原对象的属性也会同步更新。

import { reactive, toRefs } from 'vue'const user = reactive({name: 'Tom',age: 20
})const userRefs = toRefs(user)console.log(userRefs.age.value) // 20
userRefs.age.value++console.log(user.age) // 21

reactive()

定义:将一个普通Javascript对象转换为响应式对象
参数:普通对象
作用:响应式对象中的所有属性都是响应式的,当属性的值改变时,视图会自动更新。

import { reactive } from 'vue'const user = reactive({name: 'Tom',age: 20
})console.log(user.age) // 20
user.age++
// 视图自动更新


ref()用于创建简单的响应式对象;
toRef()用于将响应式对象的属性转换为单独的ref对象;
toRefs()用于将整个响应式对象转换成普通对象,每一个属性都是ref对象;
reactive()用于创建嵌套响应式对象

toRef() & toRefs()是两个不同的函数,用于处理响应式对象中的属性
在 Vue 3 中,toRefs() 和 toRef() 是两个不同的函数,用于处理响应式对象中的属性。

toRefs() 函数接受一个响应式对象,返回一个新的对象,该对象将所有属性转换为 ref 对象。这是因为当我们将响应式对象传递给子组件时,我们需要将其解构为单独的 ref 对象以避免在子组件中更改属性时破坏父组件的响应式追踪。通过使用 toRefs() 函数,我们可以将响应式对象的所有属性转换为 ref 对象,并将其传递给子组件,以便在子组件中使用属性时保持响应式追踪。

import { reactive, toRefs } from 'vue'const state = reactive({name: 'John',age: 30
})const refs = toRefs(state)
console.log(refs.name.value) // 'John'

toRef() 函数接受一个响应式对象和一个属性名称,返回一个新的 ref 对象,该对象引用响应式对象的属性。这是因为在某些情况下,我们只需要引用响应式对象的单个属性,并且不需要将整个响应式对象的属性都转换为 ref 对象。使用 toRef() 函数,我们可以将响应式对象的单个属性转换为 ref 对象。

import { reactive, toRef } from 'vue'const state = reactive({name: 'John',age: 30
})const ageRef = toRef(state, 'age')
console.log(ageRef.value) // 30
http://www.lryc.cn/news/35851.html

相关文章:

  • docker容器内安装gcc(trunk 最新版本)以及LLVM
  • 手把手教你如何做数据报表
  • loadrunner的函数lr_paramarr()学习
  • Hive---数据导出
  • 还不会CAD批量打印图纸?学会这招再也不怕
  • 硬件设计从失败案例中找方法
  • 使用python求PLS-DA的方差贡献率
  • 前端面试题--JavaScript篇
  • 【批处理脚本】-3.5-pause暂停命令详解
  • 软件测试11
  • 2023 面试题js、es6篇
  • (六十六)设计索引的时候,我们一般要考虑哪些因素呢?(下)
  • python程序设计基础 实验四
  • ASP.NET CORE API 使用Orleans
  • 《论文阅读》软化标签(将one-hot编码转变为grayscale标签)
  • keras图片数字识别入门AI机器学习
  • 使用qt编写一个程序,伪造一个ip访问一个网站。
  • 探访人工智能领跑者:纷享销客携手30+TOP高科技企业走进旷视科技
  • UTC、TimeZone、TimeStamp
  • 探究SMC局部代码加密技术以及在CTF中的运用
  • 免费集装箱箱号识别API,人工智能企业CIMCAI集装箱识别检测人工智能平台全球4千企业用户,支持API集成二次开发人工智能企业
  • pdf多页合并为一页方法总结,你觉得哪个最好?
  • 每日一读【基金/股票投资的常识和纪律】
  • 阶段二12_面向对象高级_继承3
  • C++ STL:string类的概述及常用接口说明
  • java Math类 和 System类 详解(通俗易懂)
  • 软件回归测试是什么?
  • TwinCAT3中ModbusTCP Server和C# Client连接
  • 【上传项目代码到Git详细步骤】
  • C++回顾(十五)—— 类模板