Maison > interface Web > js tutoriel > Introduction détaillée au type d'objet Blob dans js

Introduction détaillée au type d'objet Blob dans js

王林
Libérer: 2020-04-20 09:22:49
avant
3415 Les gens l'ont consulté

Introduction détaillée au type d'objet Blob dans js

Il existe généralement trois façons de construire un objet Blob :

1. Construisez-le via le constructeur de l'objet Blob.

2. Appelez l'interface slice à partir de l'objet Blob existant pour découper un nouvel objet Blob.

3. La méthode toBlob de l'API canevas convertit les informations de dessin actuelles en un objet Blob. Regardons simplement la première implémentation :

Utilisation : Nouvelle méthode pour créer des objets Blob (construits par le constructeur)

var blob = new Blob(array[optional], options[optional]);
Copier après la connexion

Constructeur, accepte deux paramètres

Premiers paramètres : C'est une séquence de données, qui peut être une valeur dans n'importe quel format, par exemple n'importe quel nombre de chaînes, Blobs et ArrayBuffers.

Le deuxième paramètre : permet de préciser le type de données à placer dans le Blob (MIME) (le backend peut obtenir le type correspondant en énumérant MimeType :

MimeType mimeType = MimeType.toEnum(file.getContentType());)。
Copier après la connexion
 <script>
 var blob = new Blob(["Hello World!"],{type:"text/plain"});
 </script>
Copier après la connexion

Blob Basic attributs de l'objet :

size : Le nombre d'octets contenus dans l'objet Blob. (Lecture seule)

type : Le type de données MIME contenu dans l'objet Blob. inconnu, une chaîne vide est renvoyée

Construction d'objet natif Blob

<script type="text/javascript">
window.onload = function() {
 var blob = new Blob(1234);
}
</script>
Copier après la connexion

Erreur d'invite :

Uncaught TypeError: Failed to construct ‘Blob&#39;: The 1st argument is neither an array, nor does it have indexed properties.
Copier après la connexion

La raison est que le constructeur Blob exige que le premier paramètre soit un. tableau, et le premier paramètre ici n'est ni un tableau, ni un attribut indexable. Puisque les attributs indexables des objets sont mentionnés ici, cela me rappelle le concept de tableau, et Arguments en est un bon exemple :

<script type="text/javascript">
function testArgumentsBlob() {
 var blob = new Blob(arguments);
 console.log(blob.size);//3
 console.log(blob.type);//""
}
window.onload = function() {
 testArgumentsBlob(1, 2, 3);
}
</script>
Copier après la connexion

. Oui. Étant donné que même s'il s'agit d'un objet de type tableau et que le type d'élément du tableau est Number, la conclusion correcte peut être tirée parce que le constructeur convertit Number en String à l'intérieur de

. sinon ! Type de paramètre :

window.onload = function() {
 var arg = {hello: "2016"};
 var blob = new Blob([JSON.stringify(arg, null, "\t")], {type: "application/json"});
 console.log(blob.type);//application/json
 console.log(blob.size);//20
}
Copier après la connexion

blob.type est égal à application/json. La longueur après la conversion de arg en chaîne est de 16 plus la largeur du caractère de tabulation t est de 4 octets, ce qui est égal à 20. .>
Méthodes de base des objets Blob :

Découpage de fichiers volumineux (méthode slice()), la méthode slice est similaire à la méthode slice du tableau. La méthode

Blob.slice([start, [end, [content-type]]])
Copier après la connexion

slice() accepte. trois paramètres. Le décalage de début, le décalage de fin et le type MIME facultatif Si le type MIME n'est pas défini, le type MIME du nouvel objet Blob est le même que celui du parent

lors du téléchargement de fichiers volumineux. très utile. Vous pouvez diviser un gros fichier en segments et les télécharger séparément, car l'objet Blob divisé existe indépendamment de l'original

Cependant, il n'existe actuellement aucune implémentation unifiée de cette méthode par les navigateurs, Firefox. utilise mozSlice(), Chrome utilise webkitSlice() et d'autres navigateurs utilisent la méthode normale slice()

Vous pouvez écrire une méthode compatible avec chaque navigateur :

 function sliceBlob(blob, start, end, type) {
 type = type || blob.type;
 if (blob.mozSlice) {
  return blob.mozSlice(start, end, type);
 } else if (blob.webkitSlice) {
  return blob.webkitSlice(start, end type);
 } else {
  throw new Error("This doesn&#39;t work!");
 }
 }
Copier après la connexion

Utilisez Blob pour afficher les vignettes

var input = document.createElement("input");
input.type = "file";
input.accept = "image/*";
input.multiple = true;
input.style.display = "none";
document.body.appendChild(input);

var fileSelect = document.createElement("a");
fileSelect.href = "#";
fileSelect.appendChild(document.createTextNode("Choose files"));
document.body.appendChild(fileSelect);

var imgList = document.createElement("div");
imgList.innerHTML = "<p>No file Selected!</p>"
document.body.appendChild(imgList);

input.addEventListener("change", function(e) {
var files = this.files;
if(!files.length) {
return;
}
imgList.innerHTML = "";
var list = document.createElement("ul");
imgList.appendChild(list);
for(var i = 0; i < files.length; i++) {
var li = document.createElement("li"); 
list.appendChild(li);

var img = document.createElement("img");
img.src = window.URL.createObjectURL(files[i]);
img.height = 60;
img.width = 60;
img.onload = function() {
window.URL.revokeObjectURL(this.src);
}
li.appendChild(img);
var info = document.createElement("span");
info.innerHTML = files[i].name + ":" + files[i].size + " bytes";
li.appendChild(info);
}
}, false);

fileSelect.addEventListener("click", function(e) {
input.click(); 
e.preventDefault();
}, false);
Copier après la connexion

Utilisez Blob pour afficher les vignettes

rrreee

Étant donné que l'objet File hérite de Blob, nous pouvons facilement utiliser l'objet File pour charger le fichier image du système local et générer une URL via createObjectURL et l'afficher :

Tutoriel js

<.>

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!

Étiquettes associées:
source:jb51.net
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal