dupd
html代码
<canvas id="canvas" width="100" height="100" ></canvas>
js 代码
var canvas=document.getElementById("canvas");
var ctx=canvas.getContext("2d");
ctx.fileStyle="gray";
ctx.fillReact(0,0,100,100);

1.直接调用canvas对象的toDataURL方法转化为指定类型

var newImg = new Image();
newImg.src=canvas.toDataURL("image/png"));

2.利用canvas对象的toBlob方法

先通过toBlob将canvas对象转化为二进制对象,通过参数形式传入函数,然后利用URL.createObjectURL方法根据传入的参数创建一个指向该参数blob对象的url,然后把url赋给img的src属性即可
canvas.toBlob && canvas.toBlob(function(blob) {
  var url = URL.createObjectURL(blob);
  var newImg = new Image();
  newImg.onload = function() {
    URL.revokeObjectURL(url)
  };
  newImg.src=url;
};
 URL.revokeObjectURL()方法会销毁一个通过URL.createObjectURL()创建的对象URL. 当你要把url赋给newImg之后,并且浏览器已经onload成功这个img,那么此时就再不需要指向blob对象的url,这个时候就应该把这个对象销毁掉,避免占用内存。

分类:

技术点:

相关文章:

  • 2021-11-02
  • 2021-10-13
  • 2021-12-23
  • 2021-12-14
  • 2021-10-16
  • 2021-10-19
  • 2021-11-20
  • 2021-12-13
猜你喜欢
  • 2021-12-18
  • 2021-12-05
  • 2021-11-05
  • 2021-11-30
  • 2021-12-05
  • 2021-08-14
  • 2021-11-28
相关资源
相似解决方案