vue3中markRaw示例详解

 更新时间:2024年04月01日 12:16:32   作者:Br不二  
markRaw是将一个对象标记为普通对象,而toRaw是将reactive对象变为普通对象,在 Vue 3 中,markRaw 是一个用于告诉 Vue 的响应性系统不要对某个对象进行转换或追踪其响应性的函数,下面给大家介绍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示例详解的文章就介绍到这了,更多相关vue3 markRaw内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 基于Vue实现本地消息队列MQ的示例详解

    基于Vue实现本地消息队列MQ的示例详解

    这篇文章为大家详细主要介绍了如何基于Vue实现本地消息队列MQ, 让消息延迟消费或者做缓存,文中的示例代码讲解详细,需要的可以参考一下
    2024-02-02
  • VUE零基础入门axios的使用

    VUE零基础入门axios的使用

    这篇文章主要介绍了axios在Vue项目中用来向后台发送请求(调接口API),获取响应信息的方法,axios 是一个轻量的 HTTP客户端,基于 XMLHttpRequest 服务来执行 HTTP 请求,需要的朋友们下面随着小编来一起学习学习吧
    2022-07-07
  • vue3使用Facebook嵌入式视频播放器API方法详解

    vue3使用Facebook嵌入式视频播放器API方法详解

    这篇文章主要为大家介绍了vue3使用Facebook嵌入式视频播放器API方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • 如何把vuejs打包出来的文件整合到springboot里

    如何把vuejs打包出来的文件整合到springboot里

    这篇文章主要介绍了如何把vuejs打包出来的文件整合到springboot里,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-07-07
  • Vue 使用Ajax异步或同步的方法

    Vue 使用Ajax异步或同步的方法

    本文介绍了Vue中使用Axios动态加载员工列表数据,并通过async/await替代then/catch优化代码结构,同时详解了Vue生命周期的8个阶段及钩子函数应用场景,强调mounted钩子用于初始化数据请求,感兴趣的朋友跟随小编一起看看吧
    2025-07-07
  • vue3自定义确认密码匹配验证规则的操作代码

    vue3自定义确认密码匹配验证规则的操作代码

    这篇文章主要介绍了vue3自定义确认密码匹配验证规则的操作代码,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2024-01-01
  • 在vue-cli 3中给stylus、sass样式传入共享的全局变量

    在vue-cli 3中给stylus、sass样式传入共享的全局变量

    这篇文章主要介绍了在vue-cli 3中, 给stylus、sass样式传入共享的全局变量,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-08-08
  • Vue渲染器如何对节点进行挂载和更新

    Vue渲染器如何对节点进行挂载和更新

    这篇文章主要介绍了Vue 的渲染器是如何对节点进行挂载和更新的,文中通过代码示例给大家介绍的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下
    2024-05-05
  • 使用Vue3-Ace-Editor如何在Vue3项目中集成代码编辑器

    使用Vue3-Ace-Editor如何在Vue3项目中集成代码编辑器

    这篇文章主要介绍了使用Vue3-Ace-Editor如何在Vue3项目中集成代码编辑器,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • 详解如何写出一个利于扩展的vue路由配置

    详解如何写出一个利于扩展的vue路由配置

    这篇文章主要介绍了详解如何写出一个利于扩展的vue路由配置,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-05-05

最新评论