Vue使用v-show,v-if绑定canvas组件时候其offsetWidth,offsetHeight为0异常问题

  网上有说是因为浮动关系,去给父级组件添加overflow:hidden,这样确实是能让js获取父级组件的offset属性,但是需要的是canvas组件的属性,往canvas上添加overflow:hidden也没能解决问题。

  然后我突然发现来回切换canvas的显示状态的时候,canvas的offset属性字段在隐藏的时候console.log了正确的大小,但是并没有显示,在显示的时候console.log却是0,但是显示了。

  也就是说,console.log输出的canvas大小一直是上一个状态的属性

  所以猜测应该是js获取当前canvas属性在vue操作canvas组件之前

  所以,将启动canvas绘制通过setTimeout异步间隔一定时间就行了。  

【Over】

posted @ 2022-08-30 16:08  Renhr  阅读(782)  评论(0)    收藏  举报