我的编程空间,编程开发者的网络收藏夹
学习永远不晚

vue3搭配pinia报错怎么解决

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

vue3搭配pinia报错怎么解决

本篇内容主要讲解“vue3搭配pinia报错怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue3搭配pinia报错怎么解决”吧!

An Object could not be cloned?

不知道有多少开发者遇到过这个报错——An Object could not be cloned

vue3搭配pinia报错怎么解决

本人这里是一个electron项目,在使用ipcRenderer.invoke通讯时传入了一个对象,就抛出了这个错了。把传入的对象打印出来,发现对象里有字段被转成了proxy对象,估计就是在ipcRenderer.invoke处理proxy的时候无法处理,因此报错。

VUE 3的toRaw

我们都知道VUE 3 相比VUE 2在响应式数据的处理上有着巨大的改动,从2的Object.defineProperty到3的proxy。而为了让用户可以自行选择是否使用响应式,VUE 3提供了 reactive,ref等API。在把数据转成响应式之后,数据就已经被VUE修改成一个新的对象了,通过打印我们可以看到。

const obj = reactive({ a: 1, b: 2 });console.log(obj);

vue3搭配pinia报错怎么解决

当然为了避免上述我遇到的这类问题,VUE 3提供了一个API让用户可以把proxy对象转回原生的对象。这个API就是toRaw()。

const obj = reactive({ a: 1, b: 2 });console.log(obj);console.log(toRaw(obj));

vue3搭配pinia报错怎么解决

有了toRaw之后,理应不会遇到什么问题了。可是在我的场景里又有一个情况,就是混用了PINIA。

PINIA与VUE 3可以混合搭配?

PINIA是公认下一代的“VUEX”,同样有着与VUEX一样的特性——与VUE搭配使用会更加流程。但要注意的一点是,PINIA并不是VUE的专属,也就是说无论你开发的是什么项目,只要用到JavaScript你就可以用PINIA。也正因此如此,似乎与前面提到的一点是冲突的,这也出现在了我的项目中。

我们先来写一个简单的PINIA store

// store.jsexport const useCounterStore = defineStore('counter', {  state: () => {    return {      myData: {        o1: {          b: 2        },        a: 1      }    }  },  actions: {    setMyData(data) {      this.myData = { ...data };    },  },})

然后在VUE中使用

import { useCounterStore } from "./stores/index.js";const counter = useCounterStore();const obj = reactive({ a: 1, b: 2 });console.log(counter.myData);counter.setMyData({newO:obj});console.log(counter.myData);

打印出来的结果如下:

vue3搭配pinia报错怎么解决

我们发现这个myData对象是一个proxy嵌套proxy的对象。当我们想要让他转成原生对象时,在VUE 3项目中很自然会想到用toRaw。

console.log('toRaw',toRaw(counter.myData))

可是打印出来的结果是没有把里面的proxy解开的。

vue3搭配pinia报错怎么解决

正因为这样所以我得到了本文最开始提到的报错信息。

同样的操作在VUE 3下的结果

遇到这样的问题,我第一时间怀疑是不是因为我在用到 setMyData中用到了解构语法。那如果同样的写法在VUE3 可行吗?我们再来试一下:

const obj = reactive({ a: 1, b: 2 });const obj2 = reactive({c:3,d:4});obj2.d = {...obj};console.log(obj2);

vue3搭配pinia报错怎么解决

我们可以看到在VUE3中解构写法的赋值,并不会出现proxy嵌套的情况。说明VUE3在对自己的响应式数据赋值的时候是做了专门的处理的。因此我们可以得到一个简单的结论:PINIA与VUE3的搭配虽然在使用上可以很自然顺畅,但他们并不是天生一对的。PINIA在数据赋值的时候没有像VUE 3一样有针对VUE 3响应式数据的处理,同时VUE 3的toRaw也没有办法为PINIA的数据完美的还原。

最后的解决方式

说完了问题的原因,简单来提一下本文错误的解决方案。其实说到底我们的目标就是要得到一个“干净”的对象。我最后用是JSON.stringify()解决的,也说明了JSON.stringify的处理是可以解决proxy嵌套的。

console.log(counter.myData);console.log(JSON.stringify(counter.myData));

vue3搭配pinia报错怎么解决

到此,相信大家对“vue3搭配pinia报错怎么解决”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

vue3搭配pinia报错怎么解决

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

vue3搭配pinia报错怎么解决

本篇内容主要讲解“vue3搭配pinia报错怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue3搭配pinia报错怎么解决”吧!An Object could not be clone
2023-06-29

Vue3+Element-plus项目自动导入报错怎么解决

本篇内容介绍了“Vue3+Element-plus项目自动导入报错怎么解决”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!前言在创建 Vue3
2023-07-02

anaconda配置python环境报错怎么解决

当在Anaconda中配置Python环境时遇到问题时,可以尝试以下解决方法:确保Anaconda已经正确安装并且环境变量已经配置正确。使用Anaconda Navigator来创建和管理Python环境,可以通过Navigator中的界面
anaconda配置python环境报错怎么解决
2024-03-15

vue3+vite:src使用require动态导入图片报错怎么解决

vue3+vite:src使用require动态导入图片报错和解决方法vue3+vite动态的导入多张图片vue3如果使用的是typescript开发,就会出现require引入图片报错,requireisnotdefined不能像使用vue2这样imgUrl:require(’…/assets/test.png’)导入,是因为typescript不支持require所以用import导入,下面介绍如何解决:使用awaitimport
2023-05-21

VUE3刷新页面报错问题Uncaught SyntaxError:Unexpected token '<'怎么解决

这篇文章主要讲解了“VUE3刷新页面报错问题Uncaught SyntaxError:Unexpected token <怎么解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“VUE3刷新页
2023-07-05

wordpress报错怎么解决

wordpress报错解决方法:1、暂时禁用所有插件;2、将主题更改为默认主题;3、 修改wp-config.php文件;4、更新固定链接设置,确保设置正确;5、检查.htaccess文件是否存在且是否可写;6、检查主题的页面模板文件是否存
2023-07-31

Assert.assertEquals报错怎么解决

今天小编给大家分享一下Assert.assertEquals报错怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。前提(
2023-06-30

es报错怎么解决

本篇文章为大家展示了es报错怎么解决,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。 数据查询范围太大问题场景:订单列表 每页10条 1000页没问题 1001页就会出现问题 1002页恢复正常
2023-06-19

SpringCloud读取Nacos配置中心报错怎么解决

这篇文章主要介绍“SpringCloud读取Nacos配置中心报错怎么解决”,在日常操作中,相信很多人在SpringCloud读取Nacos配置中心报错怎么解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”S
2023-07-05

vue-cli3.x配置全局scss报错怎么解决

这篇文章主要介绍“vue-cli3.x配置全局scss报错怎么解决”,在日常操作中,相信很多人在vue-cli3.x配置全局scss报错怎么解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”vue-cli3.
2023-06-30

SAP VL02N为DN分配HU号码报错怎么解决

本文小编为大家详细介绍“SAP VL02N为DN分配HU号码报错怎么解决”,内容详细,步骤清晰,细节处理妥当,希望这篇“SAP VL02N为DN分配HU号码报错怎么解决”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧
2023-06-05

oracle报错ora00904怎么解决

ORA-00904错误是指在SQL语句中使用了无效的列名。要解决这个错误,您可以尝试以下几个方法:1. 检查列名的拼写:确保您在SQL语句中使用的列名与数据库表中的实际列名拼写一致。Oracle是区分大小写的,所以请确保拼写正确。2. 重新
2023-08-30

idea string报错怎么解决

遇到"idea string报错"通常是由于在代码中使用了字符串操作,但是字符串的定义或者使用不符合语法规则或者逻辑要求,导致IDE(IntelliJ IDEA)报错。要解决这个问题,可以按照以下步骤进行操作:1. 仔细阅读报错信息:IDE
2023-08-14

IDEA报错java.lang.nosuchfielderror怎么解决

java.lang.NoSuchFieldError表示尝试访问或者使用一个不存在的字段。通常发生在编译时和运行时,可能是由于代码中引用了不存在的字段或者版本不一致导致的。要解决这个问题,可以按照以下步骤进行操作:检查代码中是否存在拼写错
IDEA报错java.lang.nosuchfielderror怎么解决
2024-03-05

oracle报错06512怎么解决

Oracle报错06512是一个常见的错误,通常是由于数据不一致或语法错误导致的。解决此错误的方法如下:检查SQL语句:检查你的SQL语句是否正确,包括语法、表名、列名等是否正确。可以使用Oracle的SQL语句编辑器或其他工具来检查语句的
2023-10-26

mysql version报错怎么解决

如果 MySQL 报错了,可以尝试以下方法来解决:确保 MySQL 版本兼容性:检查你的应用程序和数据库服务器的 MySQL 版本是否兼容。如果不兼容,可以尝试升级或降级 MySQL 版本。检查配置文件:检查 MySQL 的配置文件是否正确
mysql version报错怎么解决
2024-04-09

python virtualenv报错怎么解决

本篇内容主要讲解“python virtualenv报错怎么解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“python virtualenv报错怎么解决”吧!在python安装完virtua
2023-06-02

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录