# Vue3 toRef 和 toRefs 函数

🚀 优质资源分享 🚀

学习路线指引(点击解锁) 知识定位 人群定位
🧡 Python实战微信订餐小程序 🧡 进阶级 本课程是python flask+微信小程序的完美结合,从项目搭建到腾讯云部署上线,打造一个全栈订餐系统。
💛Python量化交易实战💛 入门级 手把手带你打造一个易扩展、更安全、效率更高的量化交易系统

Vue3 toRef 和 toRefs 函数

上一篇博文介绍了 vue3 里面的 ref 函数和 reactive 函数,实现响应式数据,今天主要来说一下 toRef 函数和 toRefs 函数的基本使用。

toRef 函数

通过上一篇博客,我们知道,ref 函数可以创建一个响应式的数据,那 toRef 函数同样也是创建一个响应式的数据,那么他们之间的区别是什么呢?

首先一点,ref 函数他的本质其实是去拷贝一份数据,脱离了与源数据的交互。什么意思呢?就是 ref 函数可以将对象里面的属性值变成响应式的数据,修改响应式数据,是不会影响到源数据,但是视图层上的数据会被更新。但是 toRefs 函数的本质是引用,也就是说,toRef 函数会与源数据交互,修改响应式数据会造成源数据的修改,但是他的修改不会造成视图层数据的更新。

上面这段话理解吗?不理解的话没关系,下面通过几个案例就可以明白了。

toRef 函数使用

首先呢, toRef 函数有两个参数。

toRef(操作对象, 对象属性)

好,接下来我们使用 toRef 函数写一个案例,还是和以前一样,页面展示一个用户的名称和年纪。


 <div>
 <h1>toRef toRefs 函数h1>
 <p>姓名:{
  {boy\_toRef}}p>
 <p>年龄:{
  {boy.age}}p>
 div>

<script>
 import { toRef } from 'vue'
 export default {
 setup() {
 const boy = { // 创建一个用户对象
 name: '我是𝒆𝒅.', // 用户名称
 age: 10 // 用户年龄
 }
 // 使用 toRef 函数包裹,操作 boy 对象的 name 属性
 const boy\_toRef = toRef(boy, 'name') 
 console.log(boy\_toRef) // 我们直接打印看一下包裹后的数据格式
 return { boy, boy\_toRef }
 }
 }
script>

保存代码,刷新页面。


我们可以看到数据的结构,在 value 里面直接就是 boy 下面 name 的属性值,所以说,接下来我们编写一个按钮,点击按钮,修改这个 name 值。


 <div>
 <h1>toRef toRefs 函数h1>
 <p>姓名:{
  {boy\_toRef}}p>
 <p>年龄:{
  {boy.age}}p>
 <el-button type="primary" @click="btn">修改 nameel-button>
 div>

<script>
 import { toRef } from 'vue'
 export de
  • 5
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Vue 3中,`toRef`和`toRefs`是个非常有用的函数,用于在组合式API中处理响应式数据。 首先,让我们来介绍一下`toRef`函数。`toRef`函数接收两个参数:一个响应式对象和一个属性名。它的作用是创建一个指向响应式对象某个属性的ref对象。这意味着当该属性的值发生变化时,ref对象也会相应地更新。 下面是一个示例代码: ```javascript import { reactive, toRef } from 'vue'; const state = reactive({ name: 'John', age: 25, }); const nameRef = toRef(state, 'name'); console.log(nameRef.value); // 输出:John state.name = 'Alice'; console.log(nameRef.value); // 输出:Alice ``` 在上面的代码中,我们使用`toRef`函数创建了一个指向`state`对象中`name`属性的ref对象`nameRef`。当`state.name`的值发生变化时,`nameRef.value`也会相应地更新。 接下来,让我们来介绍一下`toRefs`函数。`toRefs`函数接收一个响应式对象作为参数,并返回一个包含该对象所有属性的普通对象,其中每个属性都是一个ref对象。 下面是一个示例代码: ```javascript import { reactive, toRefs } from 'vue'; const state = reactive({ name: 'John', age: 25, }); const refs = toRefs(state); console.log(refs.name.value); // 输出:John console.log(refs.age.value); // 输出:25 state.name = 'Alice'; console.log(refs.name.value); // 输出:Alice ``` 在上面的代码中,我们使用`toRefs`函数将`state`对象转换为一个包含所有属性的普通对象`refs`。通过`refs.name.value`和`refs.age.value`,我们可以访问到对应属性的值,并且当属性的值发生变化时,ref对象也会相应地更新。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值