返回顶部
首页 > 资讯 > 精选 >vue函数toRaw和markRaw如何使用
  • 876
分享到

vue函数toRaw和markRaw如何使用

2023-07-05 20:07:25 876人浏览 安东尼
摘要

这篇文章主要介绍了Vue函数toRaw和markRaw如何使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue函数toRaw和markRaw如何使用文章都会有所收获,下面我们一起来看看吧。toRaw()函数

这篇文章主要介绍了Vue函数toRaw和markRaw如何使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue函数toRaw和markRaw如何使用文章都会有所收获,下面我们一起来看看吧。

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/354869.html(转载时请注明来源链接)

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

猜你喜欢
  • vue函数toRaw和markRaw如何使用
    这篇文章主要介绍了vue函数toRaw和markRaw如何使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇vue函数toRaw和markRaw如何使用文章都会有所收获,下面我们一起来看看吧。toRaw()函数...
    99+
    2023-07-05
  • vue函数toRaw()和markRaw()怎么使用
    这篇文章主要讲解了“vue函数toRaw()和markRaw()怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“vue函数toRaw()和markRaw()怎么使用”吧!针对一些特殊的...
    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
  • Vue3.0 API中如何使用markRaw
    这篇文章主要介绍“Vue3.0 API中如何使用markRaw”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue3.0 API中如何使用markRaw”文章能帮助...
    99+
    2024-04-02
  • vue如何使用render函数
    这篇文章主要介绍了vue如何使用render函数,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。render 函数在某些场景下你可能需要ren...
    99+
    2024-04-02
  • vue如何使用scss函数
    在vue中使用scss函数的方法:1.新建vue.js项目;2.,使用npm安装sass依赖包;3.配置webpack.base.conf.js文件;4.在style标签中添加lang=”scss”属性即可;具体步骤如下:首先,在vue-c...
    99+
    2024-04-02
  • vue中如何使用防抖函数
    在vue中使用防抖函数的方法:1.新建utils.js文件,定义防抖函数;2.创建vue.js项目;3.使用import方法引入utils.js文件;4.使用methods方法调用防抖函数;具体方法如下:首先,新建一个utils.js文件,...
    99+
    2024-04-02
  • vue函数readonly与shallowReadonly如何使用
    今天小编给大家分享一下vue函数readonly与shallowReadonly如何使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了...
    99+
    2023-07-05
  • Vue中的customRef函数如何使用
    这篇文章主要介绍了Vue中的customRef函数如何使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Vue中的customRef函数如何使用文章都会有所收获,下面我们一起来看看吧。ref是Vue官方提供的c...
    99+
    2023-07-05
  • tensor.squeeze函数和tensor.unsqueeze函数如何使用
    这篇文章主要介绍“tensor.squeeze函数和tensor.unsqueeze函数如何使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“tensor.squeeze函数和tensor.unsq...
    99+
    2023-07-05
  • vue里面如何使用构造函数
    在vue中使用构造函数的方法:1.新建html项目,引入vue;2.使用new Vue()方法定义构造函数;3.使用模板语法调用构造函数;具体方法如下:首先,新建一个html项目,并在项目中引入vue;#通过文件方式引入<script...
    99+
    2024-04-02
  • 在vue中如何使用递归函数
    在vue中使用递归函数的方法:1.新建vue.js项目;2.在项目中定义递归函数;3.使用this方法引用递归函数;4.执行代码调用递归函数;具体步骤如下:首先,在vue-cli中创建一个vue.js项目;vue init webpack ...
    99+
    2024-04-02
  • np.mean()和np.std()函数如何使用
    本篇内容主要讲解“np.mean()和np.std()函数如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“np.mean()和np.std()函数如何使用”吧!一、np.mean() 函数...
    99+
    2023-07-05
  • C++宏函数和内联函数如何使用
    今天小编给大家分享一下C++宏函数和内联函数如何使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1. 宏常量&宏函...
    99+
    2023-07-02
  • 如何在Vue中使用debouce防抖函数
    目录1.防抖函数2.Vue中使用debouce防抖函数1.防抖函数 假定两次 Ajax 通信的间隔不得小于2500毫秒,上面的代码可以改写成下面这样。 $('textarea')...
    99+
    2024-04-02
  • python如何使用Map和Filter函数
    这篇文章主要介绍了python如何使用Map和Filter函数,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Map和Filter一旦掌握了lambda表达式,学习将它们与Ma...
    99+
    2023-06-27
  • Python函数和模块如何使用
    这篇“Python函数和模块如何使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Python函数和模块如何使用”文章吧。一...
    99+
    2023-06-30
  • 如何使用 C++ 函数指针传递和调用函数?
    函数指针允许将函数作为参数传递,使函数调用更加灵活。您可以声明函数指针、传递参数,并通过指针运算符调用指向的函数。通过函数指针可以实现动态调度、排序算法选择等高级功能。 如何使用 C+...
    99+
    2024-04-17
    c++ 函数指针
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作