首页 > web前端 > js教程 > 如何从 Base64 字符串创建 JavaScript Blob?

如何从 Base64 字符串创建 JavaScript Blob?

Mary-Kate Olsen
发布: 2024-12-21 14:11:09
原创
553 人浏览过

How to Create a JavaScript Blob from a Base64 String?

在 JavaScript 中从 Base64 字符串创建 Blob

将 Base64 编码的字符串转换为 Blob 对象是 JavaScript 处理二进制数据时的常见任务。这对于将数据显示为图像或将其下载到用户的设备非常有用。

解码 Base64 字符串

第一步是解码 Base64 字符串。这可以使用 atob 函数来实现,该函数将 Base64 编码的字符串转换为包含原始二进制数据的新字符串。

const byteCharacters = atob(b64Data);
登录后复制

转换为类型化字节数组

atob 函数将产生一个字符串,每个字符代表一个字节。要将这些字符转换为实际的字节,我们可以使用 .charCodeAt 方法来获取字符代码点。这些代码点将是字节的值。

const byteNumbers = new Array(byteCharacters.length);
for (let i = 0; i < byteCharacters.length; i++) {
    byteNumbers[i] = byteCharacters.charCodeAt(i);
}
登录后复制

接下来,我们可以通过将 byteNumbers 数组传递给构造函数来创建 Uint8Array。

const byteArray = new Uint8Array(byteNumbers);
登录后复制

创建 Blob

最后,我们可以通过将 byteArray 包装在数组中并将其传递给 Blob 来创建 Blob 对象

const blob = new Blob([byteArray], {type: contentType});
登录后复制

示例

以下是如何从 Base64 字符串创建 Blob 的示例:

const contentType = 'image/png';
const b64Data = 'iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w38GIAXDIBKE0DHxgljNBAAO9TXL0Y4OHwAAAABJRU5ErkJggg==';

const blob = new Blob([atob(b64Data)], {type: contentType});
登录后复制

创建 Blob 后,您可以可以使用它向用户显示数据或将其下载到他们的设备上。您可以使用 URL.createObjectURL 函数为 Blob 创建 URL,然后可以将其设置为图像的 src 或下载链接的 href。

以上是如何从 Base64 字符串创建 JavaScript Blob?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板