微信开发者工具Canvas2D渲染报错解决方案
创作时间:
作者:
@小白创作中心
微信开发者工具Canvas2D渲染报错解决方案
引用
CSDN
1.
https://blog.csdn.net/carfge/article/details/139004729
注:本文具有时效性
背景
最近发现之前用canvas绘制的背景图,在最新版微信开发者工具控制台会报错:[渲染层错误] Uncaught TypeError: this._getData is not a function
问题
现在微信开发者工具 渲染不出背景图 ,大部分真机中渲染正常无报错,小部分安卓机(如华为Android12)渲染成功但过几秒就会引起 微信闪退 ,小程序没有抓到任何报错。
定位排查
代码一步步屏蔽排查后,发现是setData方法在设置canvas宽高时导致报错。
<view class="preview" id="preImage"> <canvas type="2d" id="foodCanvas" style="width: {{canvasWidth}}px;height: {{canvasHeight}}px;"></canvas>
解决方案
- 若知道canvas标签的父元素宽高,则可通过css设置canvas宽高均为100%,自动撑开继承父级宽高。本人在此处采用了该方案,父元素(id="preview")是flex布局计算得到的区域,不同机型宽高不同,但父元素渲染计算结果是动态固定的。修改后的代码如下:
<view class="preview" id="preImage"> <canvas type="2d" id="foodCanvas" class="canvas"></canvas>
- 若不知道canvas标签及其父元素宽高,必须动态设置宽高,则可以通过wx:if命令来动态渲染。在另一处代码,本人的修改如下:
<canvas type="2d" id="clipCanvas" class="clip-canvas" wx:if="{{imgData.canvas}}" style="width: {{imgData.canvas.width}}px;height: {{imgData.canvas.height}}px;"></canvas>
width: Math.floor(width * scale), height: Math.floor(height * scale),
最终效果
热门推荐
学行政管理好就业吗?
《幽游白书》中户愚吕:一个令人难忘的反派角色
2025考研英语目标分数?一文解读各分数段目标院校!
成都公积金封存提取指南及贷款流程详解
成都住房公积金提取指南:条件、额度、资料与方法详解
医生提醒:消炎药不宜空腹服用,否则可能伤胃
磨牙的医学原因是什么,如何进行治疗
消炎药不能盲目吃 6个注意事项要知道
互联网大厂纷纷发布通报:零容忍!辞退,移送公安
用人单位该如何辞退违反劳动纪律的员工
雷鬼音乐的起源和特征:历史、演变和全球影响
NMPA认证是什么?详解中国药品监督管理局认证体系
CPU的核心制造工艺:BGA封装技术
泥胡菜:一种兼具食用与药用价值的野生植物
了解作业指导书(SOP),看这一篇就够了!(附SOP流程图制作规范)
负热量食物吃再多也不会长胖吗
硬核拆解华为/大疆/小米硬件面试真题:手撕电路+考点思维导图(附答案)
伤口上撒盐能消毒吗?三甲医院教您如何正确处理烧/烫伤
配方奶泡好保温可以放多久?奶粉浓度泡错与结块能喝吗?婴儿喝羊奶粉的好处?
如何提升API接口的并发能力
“拉萨天团”大战游资!人气牛股尾盘“地天板”,近期龙虎榜单速览,这些席位已成常客
负卡路里的食物有哪些
立方体的计算与应用:从基础知识到实际生活中的趣味探索
最佳路线:和朋友黄山游玩四天三晚攻略
中国人有自己的“沙拉”!它真的能减脂?
小町米和长粒香米:口感特点与优质东北大米推荐
马斯克的十大创新思维理论:如何激发你的无限潜能
厦门旅游美食攻略:探寻地道小吃与特色美食全指南
韦伯望远镜在主小行星带探测到138颗直径只有十米左右的小行星
【“沂”案释法 小案大义】探望权是权利还是义务?是否可以放弃?