保存网页上canvas里的图片

用法:按键F12 打开“开发者模式”,点击“console” ,在“>” 处 粘贴   /****/ 内的代码 后,按下回车建,再执行 downloadIamge('canvas', '图片名称') 即可;功能不同可稍加扩展

/**********************************************************/

function downloadIamge(canvasName, name) {
    let image = new Image();
    image.setAttribute('crossOrigin', 'anonymous');// 解决跨域 Canvas 污染问题
    let canvas = document.getElementById(canvasName);
    let url = canvas.toDataURL('image/png')
    image.src = url;
    let a = document.createElement('a');// 生成一个a元素
    a.download = name || '下载图片名称' // 将a的download属性设置为我们想要下载的图片名称,若name不存在则使用‘下载图片名称’作为默认名称
    a.href = url;// 将生成的URL设置为a.href属性
    a.dispatchEvent(new MouseEvent('click'));// 触发a的单击事件
}
/**********************************************************/

// 调用方式 参数一: 选择器,canvase名称   参数二: 图片名称,可选
downloadIamge('canvas', '图片名称');//单一图
    
/***下载界面中多个 canvas 中的内容  参数可不传 ***/
    
function downloadIamge(canvasName, name) {
    let arr = document.getElementsByTagName("canvas");
    for(let ca of arr){
        let image = new Image();
        image.setAttribute('crossOrigin', 'anonymous');// 解决跨域 Canvas 污染问题
        let canvas = ca;
        let url = canvas.toDataURL('image/png')
        image.src = url;
        let a = document.createElement('a');// 生成一个a元素
        a.download = name || '下载图片名称' // 将a的download属性设置为我们想要下载的图片名称,若name不存在则使用‘下载图片名称’作为默认名称
        a.href = url;// 将生成的URL设置为a.href属性
        a.dispatchEvent(new MouseEvent('click'));// 触发a的单击事件
    }
}

 

// 调用方式 参数一:默认即可,不使用 参数二: 图片名称,可选
//downloadIamge('canvas', '图片名称');//单一
    

 

部分借鉴 https://www.cnblogs.com/zhangkaiqiang/p/8183926.html

扩展了一下功能

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值