HTML5中的Blob对象和MYSQL中的BLOB类型在概念上是有点区别的。MYSQL中的BLOB类型就只是个二进制数据容器。而HTML5中的Blob对象除了存放二进制数据外还可以设置这个数据的MINE类型,这相当于对文件的储存,其它很多二进制对象也是从这个对象继承的。
一个Blob
对象就是一个包含有只读原始数据的类文件对象.Blob
对象中的数据并不一定得是JavaScript中的原生形式.接口基于Blob
,继承了Blob
的功能,并且扩展支持了用户计算机上的本地文件.
创建Blob
对象的方法有几种,可以调用构造函数,还可以使用一个已有Blob
对象上的slice()方法
切出另一个Blob
对象,还可以调用对象上的toBlob
方法.
slice()方法
仍带有前缀:Firefox 12之前的版本上为 blob.mozSlice(),
Safari上为 blob.webkitSlice()
. 属性
属性名 | 类型 | 描述 |
size | unsigned long long | Blob对象中所包含数据的大小(单位字节) . 只读. |
type | 一个字符串,表明该Blob对象所包含数据的MIME类型 .如果类型未知,则该值为空字符串. 只读. |
构造函数
Blob Blob( [optional] Array parts, [optional] BlobPropertyBag properties);
参数
- 一个数组,包含了将要添加到
Blob对象中的
数据.数组元素可以是任意多个的,
(typed array), ,或者 对象. - 一个对象,设置
Blob对象的一些属性
.查看 一节.
parts
properties
方法
slice()
返回一个新的Blob
对象,包含了源Blob对象中指定范围内的数据
.
Blob slice( optional long long start, optional long long end, optional DOMString contentType};
参数
- 开始索引,可以为负数,语法类似于数组的
slice
方法.默认值为0. - 结束索引,可以为负数,语法类似于数组的
slice
方法.默认值为最后一个索引
. - 新的
Blob对象的MIME类型,
这个值将会成为新的Blob对象的
type属性的值,默认为一个空字符串
.
start
可选 end
可选 contentType
可选 返回值
一个新的Blob
对象,包含了源Blob对象中指定范围内的数据
.
注意
如果start
参数的值比源Blob对象的
size属性的值还大
,则返回的Blob
对象的size值为0,也就是不包含任何数据.
BlobPropertyBag
一个包含有两个属性type
和endings
的对象.
- 设置该
Blob对象的
type属性
. - 对应于 方法的
endings
参数.该参数的值可以是"transparent"或者"native".
type
endings(已废弃)
Blob构造函数用法举例
下面的代码:
var aFileParts = ["hey!<\/b><\/a>"];var oMyBlob = new Blob(aFileParts, { "type" : "text\/xml" }); // the blob
例子:使用类型数组和Blob对象创建一个对象URL
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上.
浏览器兼容性
Feature | Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari (WebKit) |
---|---|---|---|---|---|
Basic support | 5 | 4 | 10 | 11.10 | 5.1 |
slice() | 21 10 webkit‡ | 135 moz‡ | 10 | 12 | 5.1 () webkit |
Blob() constructor | 20 | (13.0) | 10 | 12.10 | 6 () |
注意:关于slice()的实现
slice()方法一开始
使用length来作为第二个参数
,表示需要向新的Blob对象拷贝多少个字节
.如果你指定的参数值start + length的值超过
了源Blob对象的长度
,则返回的Blob
对象包含了从start索引到源
Blob对象结束索引处的所有数据
.
这个版本的slice()
实现于, ,以及 中.可是,由于这个语法和我们常用的以及语法不同,所以已被废弃.Gecko和WebKit目前支持的是新版的slice
语法.
从Gecko 13.0 (Firefox 13.0 / Thunderbird 13.0 / SeaMonkey 2.10)和Chrome 21开始,去掉了前缀.‡
Gecko备注
在Gecko 12.0 (Firefox 12.0 / Thunderbird 12.0 / SeaMonkey 2.9)之前,方法有个bug,就是参数
start
和end
的值不能超出64位无符号数字范围,现已修复.
HTML5的Blob对象简介
HTML5中的Blob对象和MYSQL中的BLOB类型在概念上是有点区别的。MYSQL中的BLOB类型就只是个二进制数据容器。而HTML5中的Blob对象除了存放二进制数据外还可以设置这个数据的MINE类型,这相当于对文件的储存,其它很多二进制对象也是从这个对象继承的。
在稍低版本的现代浏览器中,这个Blob对象还没规范化,因此需要BlobBuilder之类的方式来创建。但是现在Blob已经规范到可以直接new它的构造器Blob来创建了,而且浏览器几乎都已经支持了这个方式,所以对于旧标准咱就没必要纠结了。var data='次碳酸钴';var blob=new Blob([data],{"type":"text/html"});console.log(blob);
var data='次碳酸钴';var blob=new Blob([data],{"type":"text/html"});onload=function(){ var iframe=document.createElement("iframe"); iframe.src=URL.createObjectURL(blob); document.body.appendChild(iframe);};