Vue3中shallowRef和shallowReactive的使用?

简介: Vue3中shallowRef和shallowReactive的使用?

为什么使用shallowRef和shallowReactive?

我们在之前的博客进过 ref 函数和 reactive 函数,他们的作用是将数据转换成响应式的数据,在修改数据的时候,可以将数据实时展示在页面上,基本数据也好,对象也好,都是这样。但是有一个问题呀,我们在把数据改为响应式数据的时候,不管是用 ref 函数还是使用 reactive 函数,他俩都是深度监听,啥意思呢? 就是 reactive 包裹的对象,就算有100层,也就是连续点一百个属性那种,去修改最深层的数据也是可以监听到的,这样的话就会存在问题了

深度监听的问题:

  • 无论 ref 函数还是 reactive 函数都是深度监听
  • 如果数据量过大,超级超级消耗性能
  • 如果我们不需要对数据进行深度监听的时候,就可以使用 shallowRef 函数和 shallowReactive 函数

前言

shallowReactive和shadowRef就是浅层的reactive和ref。可以理解成,shallowReactive只能处理引用类型,只能监听对象的最外层属性,如果深度属性发生改变,是监听不到的,没法实现响应式。shallowRef和ref不同,只能处理基本类型,不能处理引用类型。处理基本类型的时候和ref一样

shallowRef 和 shallowReactive概述区别

shallowReactive:只处理对象最外层属性的响应式(浅响应式)。
shallowRef:只处理基本数据类型的响应式, 不进行对象的响应式处理。

shallowReactive

浅层作用的响应式数据处理,也就是只处理第一层对象的数据,在往下嵌套的数据,操作数据是不起作用的;与reactive()不同,没有深层及的转换,一个浅层响应式对象里只有根级别的属性是响应式的,属性的值会被原样存储和暴露,这意味着值为ref的属性不会被自动解构

例如:如果有一个对象数据,数据结构比较深,复杂,但变化时只需要外层属性变化,那么就可以使用shallowReactive。
• 1
<template>
    <div>
      <h1>shallowReactive姓名:{{ name }}</h1>
      <h1>shallowReactive年龄:{{ news.age }}</h1>
      <button @click="reactivebtn">修改name</button>
      <button @click="btn2">修改age</button>
      <hr />
    </div>
  </template>
  <script>
  import { shallowReactive, toRefs, shallowRef } from "vue";
  export default {
    name: "App",
    setup() {
  // shallowReactive的练习
      const boy = shallowReactive(
        {  //shallowReactive 函数,只能处理第一层数据(浅响应式) 
        name: "Reactive",
        news: {
          age: 10,
        },
      }
      );
      const reactivebtn = () => {
        boy.name += 1;
      };
      const btn2 = () => {
        boy.news.age+=1;
      };
  // shallowRef的练习
  //结论:shallowReative与shallowRef在某些特殊的应用场景下,是可以提升性能的;
  // 前者针对对象,用于浅层作用的响应式数据处理,而后者只处理基本数据类型的响应式,不进行对象的响应式处理
      return { ...toRefs(boy), reactivebtn, btn2 };
    },
  };
  </script>

我们修改数据只有定义在对象第一层的属性 才是响应式的 深层次的数据将不在具有响应式的功能 因为深层次的数据将不在是一个响应式对象 而是一给普通对象

shallowRef

<template>
    <div>
      <h1>shallowRef姓名:{{ refboy }}</h1>
      <h1>shallowRef年龄:{{refobj.refnews.age  }}</h1>
      <button @click="refbtn">修改refboy</button>
      <button @click="refobj_btn">修改age</button>
    </div>
  </template>
  <script>
  import { shallowReactive, toRefs, shallowRef } from "vue";
  export default {
    name: "App",
    setup() {
  // shallowRef的练习
      const refboy = shallowRef("Ref张三"); //shallowRef 函数,只能处理基本类型数据
      const refobj = shallowRef({
        refnews: {
          birthday: "2012-10-14",
          age: 11,
        },
      });
      const refbtn = () => {
        refboy.value += "*";
      };
      const refobj_btn=()=>{
        refobj.value.refnews.age +='ref'
        console.log(refobj.value.refnews,'11');
      }
  //结论:shallowReative与shallowRef在某些特殊的应用场景下,是可以提升性能的;
  // 前者针对对象,用于浅层作用的响应式数据处理,而后者只处理基本数据类型的响应式,不进行对象的响应式处理
      return { refboy, refbtn,refobj,refobj_btn }; //, ...toRefs(boy), reactivebtn, btn2
    },
  };
  </script>

总结:

shallowReative与shallowRef在某些特殊的应用场景下,是可以提升性能的,前者针对对象,用于浅层作用的响应式数据处理,而后者只处理基本数据类型的响应式,不进行对象的响应式处理。

注意

按照vue3文档中得说明,在使用shallowRef和shallowReactive是浅响应的,即修改深层数据视图应该是不更新得,但是使用过程中往往会出现视图更新得情况;发现视图更新了,这是为什么呢?

原因是有其他响应式数据更新了,从而触发了视图更新:


相关文章
|
3月前
|
JavaScript 前端开发 安全
Vue 3
Vue 3以组合式API、Proxy响应式系统和全面TypeScript支持,重构前端开发范式。性能优化与生态协同并进,兼顾易用性与工程化,引领Web开发迈向高效、可维护的新纪元。(238字)
645 139
|
3月前
|
缓存 JavaScript 算法
Vue 3性能优化
Vue 3 通过 Proxy 和编译优化提升性能,但仍需遵循最佳实践。合理使用 v-if、key、computed,避免深度监听,利用懒加载与虚拟列表,结合打包优化,方可充分发挥其性能优势。(239字)
310 1
|
4月前
|
开发工具 iOS开发 MacOS
基于Vite7.1+Vue3+Pinia3+ArcoDesign网页版webos后台模板
最新版研发vite7+vue3.5+pinia3+arco-design仿macos/windows风格网页版OS系统Vite-Vue3-WebOS。
483 11
|
3月前
|
JavaScript 安全
vue3使用ts传参教程
Vue 3结合TypeScript实现组件传参,提升类型安全与开发效率。涵盖Props、Emits、v-model双向绑定及useAttrs透传属性,建议明确声明类型,保障代码质量。
359 0
|
5月前
|
缓存 前端开发 大数据
虚拟列表在Vue3中的具体应用场景有哪些?
虚拟列表在 Vue3 中通过仅渲染可视区域内容,显著提升大数据列表性能,适用于 ERP 表格、聊天界面、社交媒体、阅读器、日历及树形结构等场景,结合 `vue-virtual-scroller` 等工具可实现高效滚动与交互体验。
549 1
|
5月前
|
缓存 JavaScript UED
除了循环引用,Vue3还有哪些常见的性能优化技巧?
除了循环引用,Vue3还有哪些常见的性能优化技巧?
316 0
|
6月前
|
JavaScript
vue3循环引用自已实现
当渲染大量数据列表时,使用虚拟列表只渲染可视区域的内容,显著减少 DOM 节点数量。
150 0
|
4月前
|
JavaScript
Vue中如何实现兄弟组件之间的通信
在Vue中,兄弟组件可通过父组件中转、事件总线、Vuex/Pinia或provide/inject实现通信。小型项目推荐父组件中转或事件总线,大型项目建议使用Pinia等状态管理工具,确保数据流清晰可控,避免内存泄漏。
387 2
|
3月前
|
缓存 JavaScript
vue中的keep-alive问题(2)
vue中的keep-alive问题(2)
352 137
|
7月前
|
人工智能 JavaScript 算法
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
Vue 中 key 属性的深入解析:改变 key 导致组件销毁与重建
876 0