40

JavaScript 我目前使用以下方法是否有用于附加 blob 数据的功能:

var bb = new Blob(["Hello world, 2"], { type: "text/plain" });
bb = new Blob([bb, ",another data"], { type: "text/plain" });

并且BlobBuilder功能在 Chrome 中不可用。

4

1 回答 1

43

Blob是“不可变的”,因此您在制作后无法更改。构建一个将数据附加到现有 Blob 的新 Blob(如您在最初的问题中所写)是一个很好的解决方案。

如果您不需要每次追加零件时都使用 Blob,则可以只跟踪零件数组。然后您可以不断地追加到数组,然后在需要时在最后构造 Blob。

var MyBlobBuilder = function() {
  this.parts = [];
}

MyBlobBuilder.prototype.append = function(part) {
  this.parts.push(part);
  this.blob = undefined; // Invalidate the blob
};

MyBlobBuilder.prototype.getBlob = function() {
  if (!this.blob) {
    this.blob = new Blob(this.parts, { type: "text/plain" });
  }
  return this.blob;
};

var myBlobBuilder = new MyBlobBuilder();

myBlobBuilder.append("Hello world, 2");

// Other stuff ... 

myBlobBuilder.append(",another data");
var bb = myBlobBuilder.getBlob();
于 2014-07-22T00:10:01.427 回答