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

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

Linda Hamilton
Linda Hamilton原创
2024-12-19 04:25:13846浏览

How to Create a Blob from a Base64 String in JavaScript?

在 JavaScript 中从 Base64 字符串创建 Blob

问题

您在字符串中有 Base64 编码的二进制数据,并且想要创建一个包含此数据的 Blob URL 并将其显示给用户。具体来说,目标是从 Base64 字符串创建 Blob 对象,如下面的代码片段所示:

const blob = new Blob(????, {type: contentType});
const blobUrl = URL.createObjectURL(blob);

解决方案

将 Base64 字符串解码为 Blob 对象JavaScript,按照以下步骤操作:

  1. 解码base64 data:使用atob函数将base64字符串解码为字符串:

    const byteCharacters = atob(b64Data);
  2. 将字节字符转换为字节值:创建数组通过获取字节值中每个字符的字符代码点(charCode) string:

    const byteNumbers = new Array(byteCharacters.length);
    for (let i = 0; i < byteCharacters.length; i++) {
        byteNumbers[i] = byteCharacters.charCodeAt(i);
    }
  3. 创建类型化字节数组:使用 Uint8Array 构造函数将字节值转换为真正的类型化字节数组:

    const byteArray = new Uint8Array(byteNumbers);
  4. 包装在数组中并创建Blob:通过将字节数组包装在数组中并将其传递给 Blob 构造函数来创建 Blob 对象:

    const blob = new Blob([byteArray], {type: contentType});

性能优化

代码上面功能齐全,但可以通过在处理之前将字节字符切成更小的块来提高性能。

完整示例

这是一个完整的示例,从 Blob 创建图像元素:

const b64toBlob = (b64Data, contentType='', sliceSize=512) => {
  const byteCharacters = atob(b64Data);
  const byteArrays = [];

  for (let offset = 0; offset < byteCharacters.length; offset += sliceSize) {
    const slice = byteCharacters.slice(offset, offset + sliceSize);

    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);
  }

  const blob = new Blob(byteArrays, {type: contentType});
  return blob;
};

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

const blob = b64toBlob(b64Data, contentType);
const blobUrl = URL.createObjectURL(blob);

const img = document.createElement('img');
img.src = blobUrl;
document.body.appendChild(img);

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

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn