vueJs中toRaw与markRaw函数的使用比较

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

01

toRaw()函数

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

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

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

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

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

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

注意

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

02

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

总结

ref()reactive()是将一个非响应式类型数据变为响应式数据,而toRaw()markRaw()相当于是对响应式数据的还原,将一个响应式数据变为非响应式数据

toRaw只针对响应式对象类型的数据起作用,如果涉及到将一个响应式数据转变为非响应式数据,只用于纯数据的渲染,不引起页面的更新,就可以使用toRawmarkRaw()

往往可以提升数据的性能

b0a2273a3c39cb31a7b5ae072e15736c.jpeg

VueJs中的toRef与toRefs函数的一个比较


6ac0b256c7c47a4a5db3bf98b99af1d3.jpeg

Js 如何为对象拓展一个动态属性


85eb082c4361fce940fe963818a2f119.jpeg

Js如何模拟继承机制分别使用Es5和Es6来实现


3222c8008fafa4abcfe1dccf6932a3f2.jpeg

css如何隐藏垂直滚动条但同时需保持滚动

b37ecf6896462386a9190e54a6175759.jpeg

vueJs中readonly与shallowReadonly函数的使用比较


点击左下角查看更多

1cb358f2decd5dda69bea17e8bf66dd7.gif

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6
标签: vue