返回顶部
首页 > 资讯 > 精选 >vue函数toRaw()和markRaw()怎么使用
  • 586
分享到

vue函数toRaw()和markRaw()怎么使用

2023-07-05 23:07:09 586人浏览 安东尼
摘要

这篇文章主要讲解了“Vue函数toRaw()和markRaw()怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue函数toRaw()和markRaw()怎么使用”吧!针对一些特殊的

这篇文章主要讲解了“Vue函数toRaw()和markRaw()怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue函数toRaw()和markRaw()怎么使用”吧!

针对一些特殊的需求,在项目里,需要将响应式数据变为普通原始类型数据,这种情况是有的。

Vue里,能够将普通数据类型的数据变为响应式数据;同时,也能将响应式类型数据变为普通类型数据

可以用于提升数据的性能

toRaw()函数

接收一个Reactive响应式数据,将一个响应式的数据变为普通类型的数据,转化为非响应式数据,相当于还原对象,reactive相当于制作,但对于ref响应式数据不起作用。

将一个由reactive生成的响应式对象转为普通(原始)对象

toRaw()可以返回由reactive()readonly()shallowReactive()shallowReadonly()创建的代理对应的原始对象

这是一个可以用临时读取而不引起代理访问/跟踪开销,或是写入而不触发更改的特殊方法,在官方文档里,是不建议保存对原始对象的持久引用

使用场景:用于读取响应式对象的普通对象,对这个普通对象的所有操作,不会引起页面的更新

const foo = {}const reactiveFoo = reactive(foo)console.log(toRaw(reactiveFoo) === foo)  // true

注意

针对对象,后续动态新增的属性,如果没有把整个对象对外暴露出去,模板中使用新增的变量是不生效的(针对setup函数形式)

markRaw()函数

接收一个原始数据,标记一个对象,使它永远不会再成为响应式对象,也就是数据在逻辑中即使修改变化了,但是页面不会更新变化

将一个对象标记为不可被转为代理,返回该对象本身

应用场景:

[1]. 有些值不应该被设置为响应式的,例如复杂的第三方类库或Vue组件对象

[2]. 当渲染具有不可变数据源的大列表时,跳过响应式转换可以提高性能

const foo = markRaw({})console.log(isReactive(reactive(foo))) // false// 也适用于嵌套在其他响应性对象const bar = reactive({ foo })console.log(isReactive(bar.foo)) // false

markRaw()shallowReactive()这样浅层式api使你可以有选择的避开默认的深度响应/只读转换,并在状态关系谱中嵌入原始,非代理的对象

如果把一个嵌套的,没有标记的原始对象设置成一个响应式对象,然后再次访问它,你获取到的是代理的版本,这可能会导致对象身份风险

即执行一个依赖于对象身份的操作,但却同时使用了同一对象的原始版本和代理版本

const foo = markRaw({  nested: {}})const bar = reactive({  // 尽管 `foo` 被标记为了原始对象,但 foo.nested 却没有  nested: foo.nested})console.log(foo.nested === bar.nested) // false

感谢各位的阅读,以上就是“vue函数toRaw()和markRaw()怎么使用”的内容了,经过本文的学习后,相信大家对vue函数toRaw()和markRaw()怎么使用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: vue函数toRaw()和markRaw()怎么使用

本文链接: https://lsjlt.com/news/356159.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • vue函数toRaw()和markRaw()怎么使用
    这篇文章主要讲解了“vue函数toRaw()和markRaw()怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue函数toRaw()和markRaw()怎么使用”吧!针对一些特殊的...
    99+
    2023-07-05
  • vue函数toRaw和markRaw如何使用
    这篇文章主要介绍了vue函数toRaw和markRaw如何使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue函数toRaw和markRaw如何使用文章都会有所收获,下面我们一起来看看吧。toRaw()函数...
    99+
    2023-07-05
  • vue函数对比:toRaw()和markRaw()的使用
    本篇文章带大家学习vue函数,比较一下vueJs中toRaw与markRaw函数,希望对大家有所帮助!针对一些特殊的需求,在项目里,需要将响应式数据变为普通原始类型数据,这种情况是有的。在Vue里,能够将普通数据类型的数据变为响应式数据;同...
    99+
    2023-05-14
    Vue javascript
  • vueJs函数toRaw markRaw使用对比详解
    目录前言toRaw()函数markRaw()函数总结前言 针对一些特殊的需求,在项目里,需要将响应式数据变为普通原始类型数据,这种情况是有的 在Vue里,能够将普通数据类型的数据变...
    99+
    2023-05-13
    vueJs函数toRaw markRaw vueJs toRaw markRaw
  • Vue的toRef、toRefs和toRaw函数如何使用
    今天小编给大家分享一下Vue的toRef、toRefs和toRaw函数如何使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。...
    99+
    2023-07-05
  • vue函数@click.prevent怎么使用
    这篇文章主要介绍“vue函数@click.prevent怎么使用”,在日常操作中,相信很多人在vue函数@click.prevent怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue函数@click...
    99+
    2023-06-30
  • vue中Render函数怎么使用
    这篇文章主要介绍“vue中Render函数怎么使用”,在日常操作中,相信很多人在vue中Render函数怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue中Render函数怎么使用”的疑惑有所帮助!...
    99+
    2023-07-04
  • vue的辅助函数怎么使用
    本篇内容主要讲解“vue的辅助函数怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue的辅助函数怎么使用”吧! vue的辅助...
    99+
    2024-04-02
  • Vue中的computed函数怎么使用
    这篇“Vue中的computed函数怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue中的computed函数怎么...
    99+
    2023-07-05
  • vue cale()计算函数怎么使用
    本篇内容介绍了“vue cale()计算函数怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!cale()是什么calc是英文...
    99+
    2023-07-05
  • CreatePipe和CreateProcess函数怎么使用
    CreatePipe函数用于创建一个匿名管道,CreateProcess函数用于创建一个新的进程。下面是它们的使用方法:【Creat...
    99+
    2023-09-29
    CreatePipe
  • 怎么在Vue中使用debouce防抖函数
    小编给大家分享一下怎么在Vue中使用debouce防抖函数,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!1.防抖函数假定两次 Ajax 通信的间隔不得小于2500毫秒,上面的代码可以改写成下面这样。$('texta...
    99+
    2023-06-22
  • Vue中的shallowRef与shallowReactive函数怎么使用
    这篇文章主要讲解了“Vue中的shallowRef与shallowReactive函数怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue中的shallowRef与shallowRe...
    99+
    2023-07-05
  • Python排序sort()函数和sorted()函数怎么使用
    本文小编为大家详细介绍“Python排序sort()函数和sorted()函数怎么使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“Python排序sort()函数和sorted()函数怎么使用”文章能帮助大家解决疑惑,下面跟着小编的思路...
    99+
    2023-07-06
  • JavaScript函数怎么封装和使用
    本篇内容主要讲解“JavaScript函数怎么封装和使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript函数怎么封装和使用”吧!1、函数函数:...
    99+
    2024-04-02
  • Python函数和模块怎么使用
    本篇内容介绍了“Python函数和模块怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、函数和模块概述(一)函数概述函数可以看成是语...
    99+
    2023-06-22
  • JavaScript函数怎么定义和使用
    本文小编为大家详细介绍“JavaScript函数怎么定义和使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“JavaScript函数怎么定义和使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。1.用函数语句定义...
    99+
    2023-07-02
  • 怎么使用Python函数和模块
    本篇内容介绍了“怎么使用Python函数和模块”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在讲解本章节的内容之前,我们先来研究一道数学题,...
    99+
    2023-06-01
  • php函数strtr和str_replace怎么使用
    这篇文章主要讲解了“php函数strtr和str_replace怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“php函数strtr和str_replace怎么使用”吧!一....
    99+
    2023-07-04
  • Mariadb中聚合函数和分组函数怎么使用
    这篇文章主要讲解了“Mariadb中聚合函数和分组函数怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Mariadb中聚合函数和分组函数怎么使用”吧!聚合函数当我们需要汇总表中的数据而...
    99+
    2023-06-28
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作