Blob API及问题记录

接上一篇<js建立下载文件>, 记录核心部分 Blob 的API, >>传送门 , 同时说下使用过程当中碰到的一个问题.html

先说问题:web

用Blob建立后缀为.sql的文件, 内容是包含中文的文本, 结果生成的文本打开后中文部分显示乱码. 尝试加了type后,仍是没有改变. 后来想到会不会是由于.sql的mime类型问题, 因而先换成了application/stram的类型, 发现问题依旧.  后来换了个思路, type不变, 取巧把后缀换成了.txt, 结果问题就行了. 由于手上事情比较多, 苦恼之下只能先采起这个方法. 哪位朋友若是有更好的方法欢迎留言告诉我, 先谢谢.sql

<script>
    downloadFile("建立菜单SQL脚本.txt", response);

    function downloadFile(fileName, content) {
        var aLink = document.createElement('a');
        var blob = new Blob([content], { type: "text/plain" });
        var evt = document.createEvent("HTMLEvents");
        // initEvent 不加后两个参数在FF下会报错, 感谢 Barret Lee 的反馈
        evt.initEvent("click", false, false);
        aLink.download = fileName;
        aLink.href = URL.createObjectURL(blob);
        aLink.dispatchEvent(evt);
    }
</script>

 

Blob API:canvas

一个Blob对象就是一个包含有只读原始数据的类文件对象。Blob对象中的数据并不必定得是JavaScript中的原生形式。File接口基于Blob,继承了Blob的功能,而且扩展支持了用户计算机上的本地文件。api

建立Blob对象的方法有几种,能够调用Blob构造函数,还可使用一个已有Blob对象上的slice()方法切出另外一个Blob对象,还能够调用canvas对象上的toBlob方法。数组

注: 须要注意的是,一些浏览器上的 slice()方法仍带有前缀:Firefox 12以前的版本上为 blob.mozSlice(),Safari上为 blob.webkitSlice()
注: 一些浏览器提供了 BlobBuilder接口,但并非全部的浏览器都支持 BlobBuilder,并且现有的 BlobBuilder实现都是带前缀的。更主要的是 BlobBuilder已经被废弃,你应该尽量的使用 Blob构造函数来代替。

属性Edit

属性名     类型 描述
size        unsigned long long Blob对象中所包含数据的大小只读。
type DOMString 一个字符串,代表该Blob对象所包含数据的MIME类型。若是类型未知,则该值为空字符串。只读。

构造函数Edit

Blob Blob(
  [optional] Array parts,
  [optional] BlobPropertyBag properties
);
参数
parts
一个数组,包含了将要添加到 Blob对象中的数据。数组元素能够是任意多个的 ArrayBufferArrayBufferView (typed array), Blob,或者 DOMString对象。
properties
一个对象,设置 Blob对象的一些属性。查看 BlobPropertyBag一节。

方法Edit

slice()

返回一个新的Blob对象,包含了源Blob对象中指定范围内的数据浏览器

Blob slice(
  optional long long start,
  optional long long end,
  optional DOMString contentType
);

参数

start 可选
开始索引,能够为负数,语法相似于数组的 slice方法。默认值为0。
end 可选
结束索引,能够为负数,语法相似于数组的 slice方法。默认值为 最后一个索引
contentType 可选
新的 Blob对象的MIME类型,这个值将会成为新的 Blob对象的 type属性的值,默认为一个空字符串

返回值

一个新的Blob对象,包含了源Blob对象中指定范围内的数据app

注意

若是start参数的值比源Blob对象的size属性的值还大,则返回的Blob对象的size值为0,也就是不包含任何数据。ide

BlobPropertyBagEdit

一个包含有两个属性typeendings的对象。函数

type
设置该 Blob对象的 type属性
endings(已废弃)
对应于 BlobBuilder.append()方法的 endings参数。该参数的值能够是"transparent"或者"native"。

Blob构造函数用法举例Edit

下面的代码:

var aFileParts = ['<a id="a"><b id="b">hey!</b></a>'];
var oMyBlob = new Blob(aFileParts, { "type" : "text/xml" }); // the blob

等价于:

var oBuilder = new BlobBuilder();
var aFileParts = ["<a id=\"a\"><b id=\"b\">hey!<\/b><\/a>"];
oBuilder.append(aFileParts[0]);
var oMyBlob = oBuilder.getBlob("text/xml"); // the blob

BlobBuilder接口提供了另一种建立Blob对象的方式,但该方式如今已经废弃,因此不该该再使用了。

例子:使用类型数组和Blob对象建立一个对象URLEdit

var typedArray = GetTheTypedArraySomehow();
var blob = new Blob([typedArray], {type: "application/octet-binary"}); // 传入一个合适的MIME类型
var url = URL.createObjectURL(blob);
// 会产生一个相似blob:d3958f5c-0777-0845-9dcf-2cb28783acaf这样的URL字符串
// 你能够像使用一个普通URL那样使用它,好比用在img.src上。

浏览器兼容性Edit

Feature Chrome Firefox (Gecko) Internet Explorer Opera Safari (WebKit)
Basic support 5 4 10 11.10 5.1
slice()

21
10 webkit

13
5 moz
10 12 5.1 (534.29) webkit
Blob() constructor 20 13.0 (13.0) 10 12.10 6 (536.10)

 

注意:关于slice()的实现

slice()方法一开始使用length来做为第二个参数,表示须要向新的Blob对象拷贝多少个字节。若是你指定的参数值start + length的值超过了源Blob对象的长度,则返回的Blob对象包含了从start索引到源Blob对象结束索引处的全部数据

这个版本的slice()实现于Firefox 4WebKit,以及 Opera 11.10中。但是,因为这个语法和咱们经常使用的Array.slice()以及String.slice()语法不一样,因此已被废弃。Gecko和WebKit目前支持的是新版的slice语法。

从Gecko 13.0 (Firefox 13.0 / Thunderbird 13.0 / SeaMonkey 2.10)和Chrome 21开始,slice()去掉了前缀。

Gecko备注

在Gecko 12.0 (Firefox 12.0 / Thunderbird 12.0 / SeaMonkey 2.9)以前,slice()方法有个bug,就是参数startend的值不能超出64位无符号数字范围,现已修复。

相关连接Edit

相关文章
相关标签/搜索