js把base64转为可下载文件

本文介绍了一种将Base64编码的数据转换为Blob对象的方法,并通过JavaScript实现了利用Blob对象进行文件下载的功能。文章详细展示了如何解析Base64字符串、创建Blob对象以及设置必要的属性以触发文件下载。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、html代码放一个a标签

<a href=""></a>

2、js代码

	var downLoad =  document.querySelectorAll('#down a')[0];

	var downLoad =  document.querySelectorAll('#down a')[0];
        var blob = getBlob(base64Text);
		                   downLoad.setAttribute('href',URL.createObjectURL(blob));
        function getBlob(base64) {
        	console.log(getContentType(base64))
            return b64toBlob(getData(base64), getContentType(base64));
        }          
        function getContentType(base64) {
            return /data:([^;]*);/i.exec(base64)[1];
        }
 
        function getData(base64) {
            return base64.substr(base64.indexOf("base64,") + 7, base64.length);
        }
        
        function b64toBlob(b64Data, contentType, sliceSize) {
            contentType = contentType || '';
            sliceSize = sliceSize || 512;
 
            var byteCharacters = atob(b64Data);
            var byteArrays = [];
 
            for (var offset = 0; offset < byteCharacters.length; offset += sliceSize) {
                var slice = byteCharacters.slice(offset, offset + sliceSize);
 
                var byteNumbers = new Array(slice.length);
                for (var i = 0; i < slice.length; i++) {
                    byteNumbers[i] = slice.charCodeAt(i);
                }
 
                var byteArray = new Uint8Array(byteNumbers);
 
                byteArrays.push(byteArray);
            }
 
            var blob = new Blob(byteArrays, { type: contentType });
            return blob;
        }

在JavaScript中,将Base64编码的图片换为File对象可以通过以下步骤实现: 1. 创建一个Blob对象,将Base64字符串换为二进制数据。 2. 使用`File`构造函数将Blob对象换为File对象。 以下是一个示例代码,展示了如何将Base64图片换为File文件: ```javascript function base64ToFile(base64, filename) { // 去除Base64字符串中的前缀 const base64Data = base64.replace(/^data:image\/(png|jpg|jpeg);base64,/, ''); // 将Base64字符串换为二进制数据 const byteCharacters = atob(base64Data); const byteNumbers = new Array(byteCharacters.length); for (let i = 0; i < byteCharacters.length; i++) { byteNumbers[i] = byteCharacters.charCodeAt(i); } const byteArray = new Uint8Array(byteNumbers); // 创建一个Blob对象 const blob = new Blob([byteArray], { type: 'image/png' }); // 返回一个File对象 return new File([blob], filename, { type: 'image/png' }); } // 使用示例 const base64Image = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAA...'; const file = base64ToFile(base64Image, 'image.png'); console.log(file); ``` 在这个示例中,`base64ToFile`函数接受两个参数: 1. `base64`:Base64编码的图片字符串。 2. `filename`:生成的文件名。 函数内部首先去除Base64字符串的前缀,然后使用`atob`函数将Base64字符串换为二进制数据。接下来,将二进制数据换为`Uint8Array`,创建一个`Blob`对象。最后,使用`File`构造函数将Blob对象换为File对象。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值