canvas导出图片方法总结
1.直接调用canvas对象的toDataURL方法转化为指定类型
var newImg = new Image();
newImg.src=canvas.toDataURL("image/png"));
2.利用canvas对象的toBlob方法
https://developer.mozilla.org/zh-CN/docs/Web/API/HTMLCanvasElement/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,这个时候就应该把这个对象销毁掉,避免占用内存。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!