为了账号安全,请及时绑定邮箱和手机立即绑定

这样把 imageData 作为 src 属性写入 <img> 元素为什么会失败?

这样把 imageData 作为 src 属性写入 <img> 元素为什么会失败?

慕尼黑5688855 2018-09-06 10:09:02
把图片画在 canvas 里后调用其 toDataURL 方法得到 imageData 的字符串,把它写入新的<img>,插入 DOM:  const getImageData = (imageUrl) => {    let image = new Image();     image.src = imageUrl;    let canvas = document.createElement('canvas');     canvas.setAttribute('width', 300);     canvas.setAttribute('height', 300);     canvas.getContext('2d').drawImage(image, 0, 0, 300, 300);    return canvas.toDataURL();   };  let i = document.createElement('img')   i.src = getImageData('./vue-logo.png');  document.body.appendChild(i);执行后控制台里是这样的,然而元素还是空的。这是为什么?
查看完整描述

1 回答

?
慕姐4208626

TA贡献1852条经验 获得超7个赞

原因是图片没onload完毕就toDataURL(), toDataURL()应该放在image.onload 下执行


查看完整回答
反对 回复 2018-10-18
  • 1 回答
  • 0 关注
  • 1104 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信