当前位置: 首页> 健康> 美食 > HQChart使用教程100-uniapp如何在vue3运行微信小程序

HQChart使用教程100-uniapp如何在vue3运行微信小程序

时间:2025/8/23 21:39:57来源:https://blog.csdn.net/jones2000/article/details/139309202 浏览次数:0次

HQChart使用教程100-uniapp如何在vue3运行微信小程序

  • 症状
  • 原因分析
  • 解决思路
  • 解决步骤
    • 1. 修改vender.js
    • 2. 修改HQChartControl.js
  • 完整实例
  • HQChart代码地址

症状

HQChart插件在uniapp+vue3的项目编译成小程序以后, 运行会报错,见下图。
在这里插入图片描述

原因分析

查了下资料,这个Proxy是vue3特有的,我们只要让它不生成这个Proxy就可以解决这个报错。于是我继续查资料,有一个函数"markRaw"可以阻止创建Proxy。只要在这个变量赋值的时候(具体代码地址见下图)使用markRaw不创建proxy就可以了。
在这里插入图片描述
上面这图能看懂吗?获取画布节点,并且把这个节点赋值给一个变量(this.CanvasNode),由于vue3导致this.CanvasNode最后的值不是原始节点,而是一个Proxy的封装的数值。所以后续调用节点的接口函数全部报错了。

解决思路

解决方法很简单,节点赋值的地方用markRow处理下。

this.CanvasNode= markRow(res[0]);

但是问题来了, vue2里面没有这个markRow, 所有在vue2调用markRow会报错,这样我们在包装下让markRow支持vue2

//插件帮助函数
function HQChartHelper() { }
//把Vue3的markRow包装下,支持vue2
HQChartHelper.MarkRaw=function(value)
{return value;
}// #ifdef VUE3
HQChartHelper.MarkRaw=function(value)
{return markRaw(value);
}
// #endif

改完编译成小程序,问题又来个见下图
在这里插入图片描述
通过uniapp编译出来的小程序没有”markRaw“这个函数, 看了下uniapp自动生成的verndor.js,内部是有markRaw,只是没有导出,手动加上吧,并且在调用markRaw的地方加上导出的名称。这样就可以了,具体看下面的解决步骤

解决步骤

在uniapp编译好的小程序工程里面修改

1. 修改vender.js

把markRow导出,默认的文件里面没有导出markRow
在这里插入图片描述

2. 修改HQChartControl.js

把markRaw添加到插件里面帮助函数里面
在这里插入图片描述

修改完刷新下小程序就可以了。 但是每次在uniapp里面修改完了代码,都需要这样修改。相当的麻烦,反人类的设计。
在这里插入图片描述

完整实例

示例项目在群文件里面下载。
在这里插入图片描述

HQChart代码地址

地址:https://github.com/jones2000/HQChart

关键字:HQChart使用教程100-uniapp如何在vue3运行微信小程序

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: