记录–vue3中的ref,toRef,toRefs

  • 记录–vue3中的ref,toRef,toRefs已关闭评论
  • 218 次浏览
  • A+
所属分类:Web前端
摘要

  ref 接受一个原始值,返回一个具有响应式的对象,对象有一个value属性,其值就是所传递的原始值。


这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助

记录--vue3中的ref,toRef,toRefs

1. ref的使用

  ref 接受一个原始值,返回一个具有响应式的对象,对象有一个value属性,其值就是所传递的原始值。

  ref是做的一个拷贝关系,修改对象msg的值,不会影响对象obj,视图会发生变化。

    import { ref } from "vue";     let obj = { name: "你好", age: 16 };     let msg = ref(obj.name);     console.log(msg.value); // 你好     let arr = ref([]) // ref 可以是任何类型 也可以是对象     function change1() {       msg.value = "世界";        //修改msg1数据的时候必须要加 .value 渲染数据的时候就不用加了       console.log(obj, msg.value);       // {name: "你好", age: 16} '世界'        // 数据此时没改变 但是页面的数据改变了            }     change1();        return {         obj,         msg,      };

如果给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,     };   },   };

记录--vue3中的ref,toRef,toRefs

2. 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 }     }

3. 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 } }

请求过来的数据封装了一下

<script> import { reactive, toRefs } from "vue"; import { getBanner } from "@/api"; export default {   setup() {     return {       ...toRefs(getBan()),     };   }, }; function getBan() {   let bannerList = reactive({     list: [],// 模板中直接 写入 list 就可以了   });   getBanner().then((res) => {     bannerList.list = res.data;     console.log(bannerList.list);   });   return bannerList; } </script>

这样写模板中直接写入 {{ list }}  就可以了 , 不用 {{ obj.list }},修改数据的时候还是 obj.list = 'aaa' 

  import { reactive, toRefs } from "vue";   setup() {     let obj = reactive({       list: [],       newS: [],       moods: [],     });       return { ...toRefs(obj) };   },

4.总结

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

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

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

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

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

本文转载于:

https://blog.csdn.net/qq_54753561/article/details/121351993

如果对您有所帮助,欢迎您点个关注,我会定时更新技术文档,大家一起讨论学习,一起进步。

 记录--vue3中的ref,toRef,toRefs