--- title: Blob slug: Web/API/Blob translation_of: Web/API/Blob ---
Объект Blob
представляет из себя подобный файлу объект с неизменяемыми, необработанными данными; они могут читаться как текст или двоичные данные, либо могут быть преобразованы в {{DOMxRef("ReadableStream")}}, таким образом, его методы могут быть использованы для обработки данных.
Blob-ы могут представлять данные, которые не обязательно должны быть в родном для JavaScript формате. Интерфейс {{domxref("File")}} основан на Blob
, наследует функциональность Blob
и расширяет его для поддержки файлов на стороне пользователя.
Для создания Blob
не из объектов и данных blob, используйте конструктор {{domxref("Blob.Blob", "Blob()")}} . Чтобы создать blob из подмножества данных из другого blob, используйте метод {{domxref("Blob.slice()", "slice()")}}. Чтобы получить объект Blob
для файла на файловой системе пользователя, смотрите документацию на {{domxref("File")}}.
API, принимающие объекты Blob
, также перечислены в документации на {{domxref("File")}}.
Заметка: Метод slice()
имеет изначально задаваемую длину как второй аргумент, что используется для указания числа байт копируемых в новый Blob.
Если указать такие параметры start + length
, которые превышают размер исходного Blob
, то возвращаемый Blob
будет содержать данные от начального индекса (start index) до конца исходного Blob.
slice()
имеет сторонние префиксы в некоторых браузерах: blob.mozSlice()
для Firefox 12 и ранее, так же blob.webkitSlice()
в Safari. Старая версия метода slice()
, без сторонних приставок, имеет другой алгоритм и устарела. Поддержка blob.mozSlice()
была убрана в Firefox 30.Blob
, в байтах.Blob
. Если тип неизвестен, строка пуста.Blob
объект, содержащий данные в указанном диапазоне байтов исходного Blob
.Blob
.Blob
, интерпретируемое как текст UTF-8.Конструктор {{domxref("Blob.Blob", "Blob() constructor")}} может создавать объекты blob из других объектов. Например, чтобы сконструировать blob из строки JSON:
const obj = {hello: 'world'}; const blob = new Blob([JSON.stringify(obj, null, 2)], {type : 'application/json'});
До того как конструктор Blob стал доступен, это могло быть выполнено через устаревший API {{domxref("BlobBuilder")}}:
var builder = new BlobBuilder(); var fileParts = ['<a id="a"><b id="b">hey!</b></a>']; builder.append(fileParts[0]); var myBlob = builder.getBlob('text/xml');
Следующий код создает типизированный массив JavaScript и создает новый Blob
, содержащий данные типизированного массива. Затем вызывается {{DOMxRef("URL.createObjectURL()")}} для преобразования blob в {{glossary("URL")}}.
<p>This example creates a typed array containing the ASCII codes for the space character through the letter Z, then converts it to an object URL. A link to open that object URL is created. Click the link to see the decoded object URL.</p>
Основной частью этого кода для примера является функция typedArrayToURL()
, которая создает Blob
из переданного типизированного массива и возвращает объект URL для него. Преобразовав данные в URL объекта, их можно использовать несколькими способами, в том числе, в качестве значения атрибута {{htmlattrxref("src", "img")}} элементов {{HTMLElement("img")}} (конечно, при условии, что данные содержат изображение).
function typedArrayToURL(typedArray, mimeType) { return URL.createObjectURL(new Blob([typedArray.buffer], {type: mimeType})) } const bytes = new Uint8Array(59); for(let i = 0; i < 59; i++) { bytes[i] = 32 + i; } const url = typedArrayToURL(bytes, 'text/plain'); const link = document.createElement('a'); link.href = url; link.innerText = 'Open the array URL'; document.body.appendChild(link);
var typedArray = GetTheTypedArraySomehow(); var blob = new Blob([typedArray], {type: 'application/octet-binary'}); // pass a useful mime type here var url = URL.createObjectURL(blob); // url will be something like: blob:d3958f5c-0777-0845-9dcf-2cb28783acaf // now you can use the url in any context that regular URLs can be used in, for example img.src, etc.
Один из способов прочесть содержимое Blob
– это использовать {{domxref("FileReader")}}. Следующий код читает содержимое Blob
как типизированный массив.
var reader = new FileReader(); reader.addEventListener("loadend", function() { // reader.result contains the contents of blob as a typed array }); reader.readAsArrayBuffer(blob);
Другой способ прочитать содержимое из Blob
– это использовать {{domxref("Response")}}. Следующий код читает содержимое Blob
как текст:
const text = await (new Response(blob)).text();
Или можно использовать {{DOMxRef("Blob.text()")}}:
const text = await blob.text();
Используя другие методы {{domxref("FileReader")}}, возможно прочесть содержимое объекта Blob как строку или как URL.
Specification | Status | Comment |
---|---|---|
{{SpecName('File API','#blob-section','Blob')}} | {{Spec2('File API')}} | Initial definition |
{{Compat("api.Blob")}}
Для использования в коде chrome, JSM и Bootstrap scope, вы должны импортировать его следующим образом:
Cu.importGlobalProperties(['Blob']);
Blob
доступен в Worker scopes.