【uniapp】Vue3版本项目出现Proxy代理对象无法正常取值问题解决

文章讲述了在从Vue2升级到Vue3的过程中,由于Proxy代理导致的响应式对象变化问题。Vue2使用Object.defineProperty实现响应式,而Vue3采用Proxy,提高性能。当遇到无法正常取值的情况,可以使用markRaw避免对象转化为响应式,或者通过JSON序列化来处理。同时,文章介绍了isReactive和reactive等方法来检查和创建响应式对象。
摘要由CSDN通过智能技术生成

习惯了使用Vue2版本的uniapp项目,直到后来想升级版本,改用Vue3版本就会遇到一些无法正常取值(访问属性)问题,其中最显著问题就是Proxy代理造成的

在我们用浏览器调试的时候,遇到如同下图这样,出现这个data不是原来的Object对象,这是叫Proxy代理
在这里插入图片描述

Proxy代理

Proxy的意思

Proxy就是代理,可以理解为一个拦截器,当我们操作一个代理了的对象时,它都会对对象的操作进行拦截,从而进行监测和改写

  • Proxy代理是响应式对象
  • 一个对象的响应式副本

为什么会出现这个呢,vue中有如下情况肯定会发生

export default {
	data(){
		return {
			canvas:{ },//...这里定义的一些变量,都会被转换为响应式对象
		}
	}
}

要定义非响应式对象,直接在对创建的应用实例对象this设置属性如canvas即可

this.canvas = {};

Vue响应式

Vue2 实现响应式的基础原理是用方法Object.definedProperty(),实现简单的数据监听拦截,

而Vue3 就改换成了用Proxy代理,相比Vue2,其性能得到提升,

要想还原,只需调用以下这个返回对象方法即可

data = markRaw(data);

使用前,需要先导入来自Vue的方法

import { markRaw } from "vue";
//...

如果嫌markRaw没作用,就试试转JSON序列化,再还原

data = JSON.parse(JSON.stringify(data));

标记对象

标记一个对象,使其永远不会转换为 proxy,返回对象本身。

markRaw(proxy)

其它方法

检查参数是否是响应式副本(proxy)

isReactive(object) 

返回创建的响应式副本(proxy)

reactive(object)

讲到这里,学到了吗

想知道 Proxy 怎样用,点此 Javascript Proxy 前往了解

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

TA远方

谢谢!收到你的爱╮(╯▽╰)╭

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值