博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
HTML5中的二进制大对象Blob(转)
阅读量:6027 次
发布时间:2019-06-20

本文共 3303 字,大约阅读时间需要 11 分钟。

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);

参数

parts
一个数组,包含了将要添加到
Blob对象中的数据.数组元素可以是任意多个的
, (typed array),  ,或者 对象.
properties
一个对象,设置
Blob对象的一些属性.查看 一节.

方法

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对象中指定范围内的数据.

注意

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

BlobPropertyBag

一个包含有两个属性typeendings的对象.

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

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‡

13
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,就是参数startend的值不能超出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);

  这样我们就创建了一个Blob对象,注意Blob这个构造器的参数比较诡异,第一个参数是一组数据,所以必须是数组,即使像上面的例子一样只有一个字符串也必须用数组装起来。第二个参数是对这一Blob对象的配置属性,目前也只有一个type也就是相关的MIME需要设置,使用key-value的方式也许是为了今后的扩展。
  那么,把数据做成Blob有什么用呢?对于Blob对象,我们可以创建出一个URL来访问它。使用URL对象的createObjectURL方法。

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);};

  不仅是上面例子中的text/html,任何浏览器支持的类型都可以这么用。而且这个Blob-URL的生存周期是从创建到文档释放,不会造成资源的浪费。
  Blob是一个HTML5中很基本的二进制数据对象,很多方法的操作参数都支持使用Blob,这个我一下也列举不出。总之,几乎所有参数类型是二进制数据的方法都支持使用Blob作为参数就对了。所以把数据做成Blob可以让之后的一些列操作变得更方便。

转载地址:http://nkzhx.baihongyu.com/

你可能感兴趣的文章
java第二天_进制转换原理和补码存储方式作业
查看>>
js实现-限时抢购倒计时间表
查看>>
飞机游戏在C语言程序的基本语句能完成功能的体会
查看>>
JavaScript强化教程——JavaScript 运算符
查看>>
文件权限问题
查看>>
django模板&过滤器
查看>>
三座”大山“或让谷歌无人机送货项目被冻结
查看>>
使用yum快速搭建LAMP和配置phpMyAdmin
查看>>
KVM虚拟机安装、管理
查看>>
服务器硬件基础
查看>>
二周第一次课(12月18日)
查看>>
MSSQL 修改数据库的排序规则
查看>>
pyhanlp 中文词性标注与分词简介
查看>>
jS四种函数的调用方式
查看>>
linux获取内存、cpu、负载、网口流量、磁盘信息
查看>>
MySQL高可用群集------配置MMM高可用架构
查看>>
向高手进阶,从 0 开始手写实现一个 RPC 框架!
查看>>
nginx源码编译和集群及高可用
查看>>
array,vector对象 数组越界检测
查看>>
web复习day03:request
查看>>