vue3中markRaw详解

2024-04-02 23:12

本文主要是介绍vue3中markRaw详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在 Vue 3 中,markRaw 是一个用于告诉 Vue 的响应性系统不要对某个对象进行转换或追踪其响应性的函数。当你有一个对象,并且你确定你不需要它成为响应性对象时,你可以使用 markRaw 来标记它。这在一些场景中非常有用,比如当你需要集成一个第三方库或插件,并且这个库或插件的某些部分不需要是响应性的。

下面是一个详细的示例,展示了如何在 Vue 3 中使用 markRaw

import { reactive, markRaw, toRefs } from 'vue';// 创建一个普通的 JavaScript 对象
const rawObject = {name: 'Raw Object',value: 'This is a raw object and it will not be reactive.'
};// 使用 markRaw 标记这个对象,使其保持原样
const markedRawObject = markRaw(rawObject);// 创建一个响应性对象
const state = reactive({// 将标记过的 rawObject 放入响应性对象中markedRawObject,// 另一个普通的对象,它会被转换为响应性对象reactiveObject: {name: 'Reactive Object',value: 'This is a reactive object and it will track changes.'}
});// 在组件中使用这些对象
export default {setup() {// 使用 toRefs 来解构响应性对象的属性,以便在模板中直接使用const { markedRawObject, reactiveObject } = toRefs(state);// 由于 markedRawObject 是被 markRaw 标记过的,修改它不会触发 Vue 的响应性系统markedRawObject.value.name = 'Modified Raw Object'; // 这不会触发更新// 修改 reactiveObject 则会触发 Vue 的响应性更新reactiveObject.value.name = 'Modified Reactive Object'; // 这会触发更新// 返回这些属性,以便在模板中使用return {markedRawObject,reactiveObject};}
};

在上面的代码中,我们创建了一个普通的 JavaScript 对象 rawObject,并使用 markRaw 函数将其标记为原样对象。然后,我们将这个标记过的对象放入一个响应性对象 state 中。在组件的 setup 函数中,我们解构出 markedRawObjectreactiveObject,并尝试修改它们的属性。由于 markedRawObject 是被 markRaw 标记过的,所以修改它的属性不会触发 Vue 的响应性系统。而修改 reactiveObject 的属性则会触发响应性更新。

在模板中,你可以像这样使用这些属性:

<template><div><p>Marked Raw Object: {{ markedRawObject.name }} - {{ markedRawObject.value }}</p><p>Reactive Object: {{ reactiveObject.name }} - {{ reactiveObject.value }}</p></div>
</template>

请注意,即使 markedRawObject 的属性在模板中显示出来了,但由于它是原样对象,所以对其属性的修改不会触发视图的更新。而 reactiveObject 的属性修改则会触发视图的更新。

markRaw 的主要用途是当你确定某个对象不需要响应性时,避免不必要的性能开销和潜在的错误。这在处理第三方库、大型数据对象或性能敏感的场景中特别有用。

这篇关于vue3中markRaw详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/871316

相关文章

Python中局部变量和全局变量举例详解

《Python中局部变量和全局变量举例详解》:本文主要介绍如何通过一个简单的Python代码示例来解释命名空间和作用域的概念,它详细说明了内置名称、全局名称、局部名称以及它们之间的查找顺序,文中通... 目录引入例子拆解源码运行结果如下图代码解析 python3命名空间和作用域命名空间命名空间查找顺序命名空

SpringRetry重试机制之@Retryable注解与重试策略详解

《SpringRetry重试机制之@Retryable注解与重试策略详解》本文将详细介绍SpringRetry的重试机制,特别是@Retryable注解的使用及各种重试策略的配置,帮助开发者构建更加健... 目录引言一、SpringRetry基础知识二、启用SpringRetry三、@Retryable注解

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

Python中的魔术方法__new__详解

《Python中的魔术方法__new__详解》:本文主要介绍Python中的魔术方法__new__的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、核心意义与机制1.1 构造过程原理1.2 与 __init__ 对比二、核心功能解析2.1 核心能力2.2

在PyCharm中安装PyTorch、torchvision和OpenCV详解

《在PyCharm中安装PyTorch、torchvision和OpenCV详解》:本文主要介绍在PyCharm中安装PyTorch、torchvision和OpenCV方式,具有很好的参考价值,... 目录PyCharm安装PyTorch、torchvision和OpenCV安装python安装PyTor

前端下载文件时如何后端返回的文件流一些常见方法

《前端下载文件时如何后端返回的文件流一些常见方法》:本文主要介绍前端下载文件时如何后端返回的文件流一些常见方法,包括使用Blob和URL.createObjectURL创建下载链接,以及处理带有C... 目录1. 使用 Blob 和 URL.createObjectURL 创建下载链接例子:使用 Blob

Vuex Actions多参数传递的解决方案

《VuexActions多参数传递的解决方案》在Vuex中,actions的设计默认只支持单个参数传递,这有时会限制我们的使用场景,下面我将详细介绍几种处理多参数传递的解决方案,从基础到高级,... 目录一、对象封装法(推荐)二、参数解构法三、柯里化函数法四、Payload 工厂函数五、TypeScript

SpringBoot条件注解核心作用与使用场景详解

《SpringBoot条件注解核心作用与使用场景详解》SpringBoot的条件注解为开发者提供了强大的动态配置能力,理解其原理和适用场景是构建灵活、可扩展应用的关键,本文将系统梳理所有常用的条件注... 目录引言一、条件注解的核心机制二、SpringBoot内置条件注解详解1、@ConditionalOn

Qt spdlog日志模块的使用详解

《Qtspdlog日志模块的使用详解》在Qt应用程序开发中,良好的日志系统至关重要,本文将介绍如何使用spdlog1.5.0创建满足以下要求的日志系统,感兴趣的朋友一起看看吧... 目录版本摘要例子logmanager.cpp文件main.cpp文件版本spdlog版本:1.5.0采用1.5.0版本主要

Linux ls命令操作详解

《Linuxls命令操作详解》通过ls命令,我们可以查看指定目录下的文件和子目录,并结合不同的选项获取详细的文件信息,如权限、大小、修改时间等,:本文主要介绍Linuxls命令详解,需要的朋友可... 目录1. 命令简介2. 命令的基本语法和用法2.1 语法格式2.2 使用示例2.2.1 列出当前目录下的文