有base64链接,下载图片(vue)

本文介绍了一种使用Base64编码的图片数据进行下载的方法。通过JavaScript实现了从Base64转换为Blob对象,并创建了一个隐藏的a标签来触发文件下载。此方法适用于网页环境中动态生成或需要下载的图片。

有链接下载图片

 //下载图片
      download() {
        let imgData = 'base64---------';//这里放需要下载的base64
        this.downloadFile('测试.png', imgData);
      },
      //下载
      downloadFile(fileName, content) {
        let aLink = document.createElement('a');
        let blob = this.base64ToBlob(content); //new Blob([content]);
 
        let evt = document.createEvent("HTMLEvents");
        evt.initEvent("click", true, true);//initEvent 不加后两个参数在FF下会报错  事件类型,是否冒泡,是否阻止浏览器的默认行为
        aLink.download = fileName;
        aLink.href = URL.createObjectURL(blob);
 
        // aLink.dispatchEvent(evt);
        aLink.click()
      },
      //base64转blob
      base64ToBlob(code) {
        let parts = code.split(';base64,');
        let contentType = parts[0].split(':')[1];
        let raw = window.atob(parts[1]);
        let rawLength = raw.length;
 
        let uInt8Array = new Uint8Array(rawLength);
 
        for (let i = 0; i < rawLength; ++i) {
          uInt8Array[i] = raw.charCodeAt(i);
        }
        return new Blob([uInt8Array], {type: contentType});
      },
Vue下载Base64图片可以通过以下步骤实现: 1. 首先,将Base64图片数据转换为Blob对象。可以使用`atob`函数将Base64字符串解码为二进制数据,然后创建一个Uint8Array数组,并将解码后的数据存入其中。最后,使用`new Blob()`函数将数组转换为Blob对象。 ```javascript function base64ToBlob(base64Data) { const byteCharacters = atob(base64Data); const byteArrays = []; for (let offset = 0; offset < byteCharacters.length; offset += 512) { const slice = byteCharacters.slice(offset, offset + 512); const byteNumbers = new Array(slice.length); for (let i = 0; i < slice.length; i++) { byteNumbers[i] = slice.charCodeAt(i); } const byteArray = new Uint8Array(byteNumbers); byteArrays.push(byteArray); } return new Blob(byteArrays, { type: 'image/png' }); // 根据实际图片类型进行修改 } ``` 2. 创建一个下载链接并设置其属性。使用`URL.createObjectURL()`函数创建一个临时的URL,然后将其赋值给下载链接的`href`属性。同时,设置链接的`download`属性为所需的文件名。 ```javascript function downloadImage(blob, fileName) { const url = URL.createObjectURL(blob); const link = document.createElement('a'); link.href = url; link.download = fileName; link.click(); URL.revokeObjectURL(url); } ``` 3. 调用上述函数进行下载。在Vue组件中,可以在需要下载图片的地方调用上述函数,传入Base64数据和文件名。 ```javascript // 在Vue组件中的方法中调用 downloadBase64Image() { const base64Data = '...'; // 替换为实际的Base64图片数据 const fileName = 'image.png'; // 替换为实际的文件名 const blob = base64ToBlob(base64Data); downloadImage(blob, fileName); } ``` 这样,当调用`downloadBase64Image`方法时,会触发下载操作,将Base64图片保存为文件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值