Html canvas保存为图片的常见写法

  1. 最简单的
const canvas = document.getElementById('my-canvas');
const dataURL = canvas.toDataURL('image/png');
const link = document.createElement('a');
link.download = 'my-canvas.png';
link.href = dataURL;
link.click();
  1. 使用FileReader
const canvas = document.getElementById('myCanvas');
const dataURL = canvas.toDataURL('image/png');
const blob = dataURLtoBlob(dataURL);

function dataURLtoBlob(dataURL) {
  const arr = dataURL.split(',');
  const mime = arr[0].match(/:(.*?);/)[1];
  const bstr = atob(arr[1]);
  let n = bstr.length;
  const u8arr = new Uint8Array(n);
  while (n--) {
    u8arr[n] = bstr.charCodeAt(n);
  }
  return new Blob([u8arr], { type: mime });
}

const reader = new FileReader();
reader.readAsDataURL(blob);
reader.onloadend = function() {
  const base64data = reader.result;
  const a = document.createElement('a');
  a.href = base64data;
  a.download = 'canvas.png';
  a.click();
};
  1. 方法二的优化
const canvas = document.getElementById('myCanvas');
canvas.toBlob(function(blob) {
  const url = URL.createObjectURL(blob);
  const a = document.createElement('a');
  a.href = url;
  a.download = 'canvas.png';
  a.click();
});
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值