将数据文件转换为 BLOB

76

如何获取 Blob?

HTML:

<input type="file" onchange="previewFile()">

JavaScript:

function previewFile() {
  var file    = document.querySelector('input[type=file]').files[0];
  var reader  = new FileReader();

  // Get blob?
  console.log(file);
}

24
file instanceof Blob; // true - Paul S.
3个回答

113

正如评论中所指出的,file是一个blob对象:

file instanceof Blob; // true

你可以使用文件读取器API获取其内容。https://developer.mozilla.org/en/docs/Web/API/FileReader

阅读更多:https://developer.mozilla.org/en-US/docs/Using_files_from_web_applications

var input = document.querySelector('input[type=file]');
var textarea = document.querySelector('textarea');

function readFile(event) {
  textarea.textContent = event.target.result;
  console.log(event.target.result);
}

function changeFile() {
  var file = input.files[0];
  var reader = new FileReader();
  reader.addEventListener('load', readFile);
  reader.readAsText(file);
}

input.addEventListener('change', changeFile);
<input type="file">
<textarea rows="10" cols="50"></textarea>


2
@rafaelcastrocouto,@Daniel:如果我想通过WebSocket发送blob,那么从上面的代码中需要发送哪个对象?我应该发送ws.send(reader)吗? - Samuel

23

一个文件对象是 Blob 的实例,但 Blob 对象不是 File 的实例。

new File([], 'foo.txt').constructor.name === 'File' //true
new File([], 'foo.txt') instanceof File // true
new File([], 'foo.txt') instanceof Blob // true

new Blob([]).constructor.name === 'Blob' //true
new Blob([]) instanceof Blob //true
new Blob([]) instanceof File // false

new File([], 'foo.txt').constructor.name === new Blob([]).constructor.name //false

如果您必须将文件对象转换为Blob对象,则可以使用文件的数组缓冲区创建新的Blob对象。请参见以下示例。

const file = new File(['hello', ' ', 'world'], 'hello_world.txt', {type: 'text/plain'});
//or const file = document.querySelector('input[type=file]').files[0];
const reader = new FileReader();
reader.onload = function(e) {
    const blob = new Blob([new Uint8Array(e.target.result)], {type: file.type });
    console.log(blob);
};
reader.readAsArrayBuffer(file);

正如 @bgh 指出的那样,您还可以使用文件对象的arrayBuffer方法。请参见下面的示例。

const file = new File(['hello', ' ', 'world'], 'hello_world.txt', {type: 'text/plain'});
//or const file = document.querySelector('input[type=file]').files[0];

file.arrayBuffer().then((arrayBuffer) => {
    const blob = new Blob([new Uint8Array(arrayBuffer)], {type: file.type });
    console.log(blob);
});
如果您的环境支持async/await,您可以使用下面的一行代码。
const fileToBlob = async (file) => new Blob([new Uint8Array(await file.arrayBuffer())], {type: file.type });
console.log(await fileToBlob(new File(['hello', ' ', 'world'], 'hello_world.txt', {type: 'text/plain'})));

5
现在使用 arrayBuffer() 方法可能是一个更好的选择(https://developer.mozilla.org/zh-CN/docs/Web/API/Blob/arrayBuffer)。可以尝试以下代码:let blob = new Blob(await file.arrayBuffer()); - bgh

-1
async function FileToString (file) {
    try {
        let res = await file.raw.text();
        console.log(res);
    } catch (err) {
        throw err;
    }
}

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接