当前位置:首页 > 每日看点 > 正文内容

vue3响应性数组用ref还是reactive呢?

卡卷网10个月前 (01-10)每日看点139

事情是这样的,我和同事在vue3中到底是使用ref还是reactive起了争执。

我觉得应该更好的使用ref,Ref既能声明基本数据类型,也能声明对象和数组,而且不容易失去响应式,reactive作不当容易失去响应式。

而同事认为开发表单或多个值的时候都会优先采用reactive,数据集中,结构明了。

所以结果就是我准备写这篇文章来记录一下这两者的区别和用法。

ref和Reactive的区别

    <>数据类型:
    ref主要用于基本数据类型(如字符串、数字、布尔值等)以及引用数据类型(对象)。使用ref定义的数据可以通过.value属性访问和修改。reactive主要用于将对象转换为响应式数据,包括复杂的嵌套对象和数组。使用reactive定义的数据可以直接访问和修改属性。
    <>访问方式:
    ref通过.value属性访问和修改值。reactive直接访问和修改对象的属性,不需要使用.value
    <>响应性追踪:
    ref追踪单个的引用,即只有当.value属性被访问或修改时才会触发依赖追踪。reactive追踪整个对象及其内部属性,当任何属性被修改时,所有依赖于这些属性的视图都会自动更新。
    <>可变性:
    ref的引用值可以重新赋值,而不会影响其响应性。reactive对象本身是不可重新赋值的,只能修改其内部属性。如果直接重新赋值整个对象,会导致响应性丢失。

ref的使用注意事项

    <>必要性:ref应该只在必要时使用,因为它可能会影响性能。<>内存泄漏:确保在组件销毁时解除对ref的引用,以避免内存泄漏。<>值的可变性:ref的值是可变的,所以要小心地使用它,避免意外地修改其值。

reactive的使用注意事项

    <>重新赋值问题:对于reactive对象,不能直接重新赋值整个对象,否则会失去响应性。应通过修改对象的属性来保持响应性。<>解构赋值问题:解构赋值会导致响应性丢失,因为解构后的新变量不是响应式的。可以使用toRefs函数将响应式对象转换为包含多个ref的对象,以确保每个属性保持响应性。

应用场景和示例代码

ref的应用场景

简单数据:需要单一的基本数据类型,如计数器、开关状态等。 import{ref}from'vue'; constcount=ref(0); functionincrement(){ count.value++; }

    <>模板中解构响应式对象:在组合式API中,如果将响应式对象解构到模板中,ref可以保持解构后的响应性。

import{ref,toRefs}from'vue'; conststate=ref({count:0,name:'Vue'}); constcount=toRefs(state).count; constname=toRefs(state).name;

    <>引用DOM元素:在模板中引用DOM元素时,可以使用ref进行挂载。

<template> <inputref="inputElement"/> <utton@click="focusInput">FocusInput</utton> </template> <scriptsetup> import{ref}from'vue'; constinputElement=ref(null); constfocusInput=()=>{ inputElement.value.focus(); }; </script>

reactive的应用场景

    <>复杂对象和嵌套数据:当需要包含多个属性和嵌套结构的对象时,reactive更加适合。

import{reactive}from'vue'; constuser=reactive({ name:'John', age:30, address:{ city:'NewYork', country:'USA' } });

    <>性能考虑:在某些情况下,使用reactive可能会在性能上更优,因为它避免了频繁的.value访问。

创作不易,如果这篇文章对你有用,欢迎点赞关注加评论哦

小伙伴们在工作中还遇到过应用场景吗,欢迎评论区留言讨论哦。

扫描二维码推送至手机访问。

版权声明:本文由卡卷网发布,如需转载请注明出处。

本文链接:https://www.kajuan.net/ttnews/2025/01/8401.html

分享给朋友:

相关文章

1个月5款APP,陌生人社交又火了:当年经纬投陌陌,暴赚11亿美金

1个月5款APP,陌生人社交又火了:当年经纬投陌陌,暴赚11亿美金

互联网巨头们正在陌生人社交领域疯狂试探。 这是陌生人社交罕见热闹的一幕。今年 10 月底,映客完成 8500 万美元收购陌生人社交软件“积目”;进入 11 月之后,前有百度推出匿名社交APP“听筒”,后有腾讯低...

现在手里有一万闲钱,买什么币好?

今天是2024年7月29日,看看我的持仓吧。只有几百刀的那些微持仓就不说了,以下持仓都在几千刀~几万刀不等。不构成任何投资建议,成本是多次买入的大致均摊成本$TIA 成本0$DYM 成本0 $SAGA 成本0$STRK 成本0$ETHFI...

手机用久了,垃圾都在哪里,总是内存显示不够,还很卡,这可怎么解决?

手机用久了,垃圾都在哪里,总是内存显示不够,还很卡,这可怎么解决?

大家的手机在使用一段时间之后啊,是不是都会出现又卡又慢的情况,尤其是安卓手机,这种现象更是非常明显,而且很多朋友啊,也都知道手机之所以会出现这些问题,一般都是手机安装了大量软件,而这些软件在使用过程中会产生大量的缓存垃圾,因此啊时间久了就会...

有没有推荐什么手游搬砖,或者是用手机就能做的工作能日入100左右就好了?

有没有推荐什么手游搬砖,或者是用手机就能做的工作能日入100左右就好了?

大家好,我是思聪。思聪游戏搬砖社每天分享真实靠谱的游戏赚钱的方法。整个游戏的攻略用一句话概括就是:打元宝兑换平台物品,xx元宝兑换一个分红物品。你把你打游戏得来的元宝去兑换平台的分红物品,就能每天领取xx元的分红。(具体看是哪个分红物品,比...

网页上的视频怎么下载呀?

网页上的视频怎么下载呀?

1、贝贝BiliBili - B站视频下载https://xbeibeix.com/api/bilibili/贝贝BiliBili 是个免费、免登录的bilibili视频下载工具,没有任何套路。把视频链接粘贴进去 → 输入验证码 → 解析视...

WordPress建站同时面向B端和C端,有什么好的解决方案?

这个很容易实现呀,只不过需要自己开发,整体用权限管理就可以实现了,B端和C端是不同用户权限,C端能看到的菜单入口和B端不一样就行了。技术层面实现没问题的,只不过就是看你们的技术能力和投入了 ,这样的需求应该没有现成的开源插件。只能找人定制开...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。