vue生成图片保存到本地

第一步

npm install html2canvas

代码

<button @click="SaveCanvas">下载图片</button>
//点击保存为Canvas
        SaveCanvas() {
            // 这里的类名要与点击事件里的一样
            const canvas = document.querySelector(".menu");
            let that = this;
            html2canvas(canvas, { scale: 2, logging: false, useCORS: true }).then(
                function (canvas) {
                    const type = "png";
                    let imgData = canvas.toDataURL(type);
                    // 图片格式处理
                    let _fixType = function (type) {
                        type = type.toLowerCase().replace(/jpg/i, "jpeg");
                        let r = type.match(/png|jpeg|bmp|gif/)[0];
                        return "image/" + r;
                    };
                    imgData = imgData.replace(_fixType(type), "image/octet-stream");
                    let filename = "htmlImg" + "." + type;
                    // 保存为文件
                    //  以bolb文件下载
                    that.downFileToLocal(filename, that.convertBase64ToBlob(imgData));
                }
            );
        },

        // base64转化为Blob对象
        convertBase64ToBlob(imageEditorBase64) {
            let base64Arr = imageEditorBase64.split(",");
            let imgtype = "";
            let base64String = "";
            if (base64Arr.length > 1) {
                //如果是图片base64,去掉头信息
                base64String = base64Arr[1];
                imgtype = base64Arr[0].substring(
                    base64Arr[0].indexOf(":") + 1,
                    base64Arr[0].indexOf(";")
                );
            }
            // 将base64解码
            let bytes = atob(base64String);
            //let bytes = base64;
            let bytesCode = new ArrayBuffer(bytes.length);
            // 转换为类型化数组
            let byteArray = new Uint8Array(bytesCode);

            // 将base64转换为ascii码
            for (let i = 0; i < bytes.length; i++) {
                byteArray[i] = bytes.charCodeAt(i);
            }
            // 生成Blob对象(文件对象)
            return new Blob([bytesCode], { type: imgtype });
        },
        // 下载Blob流文件
        downFileToLocal(fileName, blob) {
            // 创建用于下载文件的a标签
            const d = document.createElement("a");
            // 设置下载内容
            d.href = URL.createObjectURL(blob);
            // 设置下载文件的名字
            d.download = fileName;
            // 界面上隐藏该按钮
            d.style.display = "none";
            // 放到页面上
            document.body.appendChild(d);
            // 点击下载文件
            d.click();
            // 从页面移除掉
            document.body.removeChild(d);
            // 释放 URL.createObjectURL() 创建的 URL 对象
            window.URL.revokeObjectURL(d.href);
        },

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值