Maison > interface Web > js tutoriel > Comment convertir une chaîne Base64 en blob en JavaScript ?

Comment convertir une chaîne Base64 en blob en JavaScript ?

Linda Hamilton
Libérer: 2024-12-24 16:09:15
original
770 Les gens l'ont consulté

How to Convert a Base64 String to a Blob in JavaScript?

Création d'un blob à partir d'une chaîne Base64 en JavaScript

Lorsque vous travaillez avec des données binaires codées sous forme de chaîne base64, il peut être nécessaire de convertir dans un objet Blob. Cela peut être utile pour afficher les données dans un navigateur Web ou les enregistrer sur l'appareil de l'utilisateur.

Décoder la chaîne Base64

La première étape consiste à décoder la chaîne Base64. chaîne en une chaîne de caractères octets. Ceci peut être réalisé en utilisant la fonction atob.

const byteCharacters = atob(b64Data);
Copier après la connexion

Conversion des caractères d'octets en un tableau d'octets

Ensuite, nous devons convertir le caractères d'octets dans un véritable tableau d'octets typé. Cela peut être fait en passant les caractères d'octet au constructeur Uint8Array.

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

const byteArray = new Uint8Array(byteNumbers);
Copier après la connexion

Création de l'objet Blob

Enfin, nous pouvons envelopper le tableau d'octets dans un tableau et transmettez-le au constructeur Blob pour créer le Blob objet.

const blob = new Blob([byteArray], {type: contentType});
Copier après la connexion

Optimisation des performances

Le code ci-dessus fonctionne, mais ses performances peuvent être améliorées en traitant les caractères d'octet en tranches plus petites. Une taille de tranche de 512 octets est généralement un bon choix.

Exemple de fonction

Voici une fonction qui convertit une chaîne base64 en un objet Blob en utilisant l'approche optimisée :

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;
};
Copier après la connexion

Exemple d'utilisation

Pour utiliser la fonction, transmettez simplement la chaîne base64 et le type de contenu comme arguments.

const blob = b64toBlob(b64Data, contentType);
Copier après la connexion

L'objet Blob résultant peut ensuite être utilisé pour créer une image ou télécharger les données.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal