vue3里面使用ref和toRef、toRefs

vue3 里面我们经常会使用ref()来接受内部值返回一个响应式的对象。创建可以使用任何类型的响应式ref。这里对象是响应式的,可以进行更改的,对象有一个value属性,其值就是所传递的原始值。ref() 将传入参数的值包装为一个带 .value 属性的 ref 对象。

ref、toRef、toRefs 都可以将某个对象中的属性变成响应式数据

ref的本质是拷贝,修改响应式数据,不会影响到原始数据,视图会更新
toRef、toRefs的本质是引用,修改响应式数据,会影响到原始数据,视图不会更新

toRef 一次仅能设置一个数据,接收两个参数,第一个参数是哪个对象第二个参数是对象的哪个属性

toRefs****接收一个对象作为参数,它会遍历对象身上的所有属性,然后挨个调用toRef执行

一、ref的使用

1、ref 对象是可更改的,即可以为 .value 赋予新的值

const a = ref(1);
// 为 a.value 赋予新的值
a.value = 2;
console.log("a--->", a);
console.log("a.value--->", a.value);

在这里插入图片描述

2、ref 对象是响应式的,即所有对 .value 的操作都将被追踪,并且写操作会触发与之相关的副作用。

ref()方法允许创建可以使用任何值类型的响应式 ref

ref 的 .value 属性也是响应式的。

当ref的值为对象类型时,会用 reactive() 自动转换它的 .value。

栗子:一个包含对象类型值的 ref 可以响应式地替换整个对象

const b = ref({
    name: 'vue3' });
// 响应式替换
b.value = {
    name: 'vite' };
console.log("b--->", b);
console.log("b.value--->", b.value);

在这里插入图片描述
ref 被传递给函数或是从一般对象上被解构时,不会丢失响应性:

总结:ref() 让我们能创造一种对任意值的 “引用”,并能够在不丢失响应性的前提下传递这些引用。这个功能很重要,因为它经常用于将逻辑提取到组合函数中。

3、如果给dom上加ref 就是当前的dom元素

<template>
  <div class="home-new">  
      <div ref="target">
       
      </div>
  </div>
</template>
import {
   ref} from 'vue'
export default {
   
  name: "HomeNew",
  setup(p, {
     emit }) {
   
    const target = ref(null);
    // 懒加载
    console.log(target);
    return {
   
      target,
    };
  }, 
};

在这里插入图片描述

二、toRef的使用

toRef用来给抽离响应式对象中的某一个属性,并把该属性包裹成ref对象,使其和原对象产生链接

toRef是做的一种引用关系,修改msg2的值,会影响对象msg,但视图不会发生变化

 setup(){
   
	let msg = {
    name: 'zs', age: 16 }
    let msg2 = toRef(msg, 'name')
    console.log(msg2.value)	// zs
    function change2() {
   
        msg2.value = 'ww'
        console.log(msg, msg2.value) // {name: "ww", age: 16} ww
        //此时 msg.ww 数据变了 但是视图上的是不会变的
    }
    change2()
    return {
    msg2,change2 }
    }

三、toRefs的使用

toRefs用来把响应式对象转换成普通对象,把对象中的每一个属性,包裹成ref对象

toRefs就是toRef的升级版,只是toRefs是把响应式对象进行转换,其余的特性和toRef无二

setup(){
   
    let msg = {
    name: 'zs', age: 16 }
    let msg3 = toRefs(msg)
    console.log(msg) // { name:ref, age:ref }  ref代指ref对象
    function change3() {
   
      msg3.name.value = 'zl'
      msg3.age.value = 20
      console.log(msg, msg3) // {name: "zl", age: 20} { name:ref, age:ref }
    }
    change3()
    return {
    msg3, change3 }
}

相关推荐

  1. vueref $refs使用

    2023-12-06 15:02:03       56 阅读
  2. vue3使用ref

    2023-12-06 15:02:03       37 阅读
  3. Vue3 ReactiveRef

    2023-12-06 15:02:03       35 阅读
  4. Vue3:组件间通信-$refs$parent的使用

    2023-12-06 15:02:03       35 阅读
  5. Vue3refreactive

    2023-12-06 15:02:03       47 阅读
  6. Vue3Ref ShallowRef 的区别

    2023-12-06 15:02:03       46 阅读
  7. vue3 ref reactive 区别

    2023-12-06 15:02:03       35 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-06 15:02:03       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-06 15:02:03       106 阅读
  3. 在Django里面运行非项目文件

    2023-12-06 15:02:03       87 阅读
  4. Python语言-面向对象

    2023-12-06 15:02:03       96 阅读

热门阅读

  1. MySQL数据库基础

    2023-12-06 15:02:03       34 阅读
  2. Pgsql常用命令

    2023-12-06 15:02:03       56 阅读
  3. 全民 K 歌音频相关技术分享

    2023-12-06 15:02:03       65 阅读
  4. Docker compose启动服务遇到的问题

    2023-12-06 15:02:03       50 阅读
  5. (UM1724) STM32 Nucleo-64 boards User manual

    2023-12-06 15:02:03       50 阅读
  6. conda的使用教程总结

    2023-12-06 15:02:03       44 阅读