htmlcanvas2 传入节点生成图片

/**

  • htmlcanvas2 传入节点生成图片
    */
    canvas canvas.toDataURL 图片太大会导致保存失败,解析出来的超出了浏览器对于url的限制 故使用canvas.toBlob
import html2canvas from 'html2canvas';
/**
 * htmlcanvas2  传入节点生成图片
 * @param {*} node 节点
 */
export function captureScreen(node) {
    // 调用html2canvas插件
    html2canvas(node, {
        allowTaint: false,
        foreignObjectRendering: true,
        taintTest: false,
        useCORS: true,//火狐浏览器添加项
    }).then(canvas => {
        var image = canvas.toDataURL("image/png").replace("image/png", "image/octet-stream");
        var userAgent = navigator.userAgent;
        //判断是否是IE11
        if (-1 !== userAgent.indexOf("Trident")) {
            var arr = image.split(',');
            var mime = arr[0].match(/: (.*?);/)[1];
            var bstr = atob(arr[1]);
            var n = bstr.length;
            var u8arr = new Uint8Array(n);
            while (n--) {
                u8arr[n] = bstr.charCodeAt(n);
            }
            window.navigator.msSaveBlob(new Blob([u8arr], { type: mime }), "download.png");
        } else {
            canvas.toBlob(function (blob) {
                const eleLink = document.createElement('a');
                eleLink.download = "img.png";
                eleLink.style.display = 'none';
                // 字符内容转变成blob地址
                eleLink.href = URL.createObjectURL(blob);
                // 触发点击
                document.body.appendChild(eleLink);
                eleLink.click();
                // 然后移除
                document.body.removeChild(eleLink);
            }, 'image/png', 1);
        }
    })
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值