首页 > 作文

深入解析HTML5中的Blob对象的使用

更新时间:2023-04-06 14:18:52 阅读: 评论:0

html5中的blob对象和mysql中的blob类型在概念上是有点区别的。mysql中的b炒湖蟹是哪个地方的菜lob类型就只是个二进制数据容器。而html5中的blob对象除了存放二进制数据外还可以设置这个数据的mine类型,这相当于对文件的储存,其它很多二进制对象也是从这个对象继承的。
  在稍低版本高考数学真题的现代浏览器中,这个blob对象还没规范化,因此需要blobbuilder之类的方式来创建。但是现在blob已经规范到可以直接new它的构造器blob来创建了,而且浏览器几乎都已经支持了这个方式,所以对于旧标准咱就没必要纠结了。

css code
复制内容到剪贴板

vardata=‘<bstyle=”font-size:32px;color:red;”>次碳酸钴</b>’; varblob=newblob([data],{“type”:“text/html”}); console.log(blob);

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

css code
复制内容到剪贴板

vardata=‘<bstyle=”font-size:32px;color:red;”>次碳酸钴</b>’; varblob=newblob([data],{“t出去玩的作文ype”:“text/html”}); onload=function(){ variframe=document.createelement(“iframe”); iframe.src=url.createobjecturl(blob); document.body.appendchild(iframe); };

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

方法

slice()

返回一个新的blob对象,包含了源blob对象中指定范围内的数据.

css code
复制内容到剪贴板

blobslice( optionallonglongstart, optionallonglongend, optionaldomstringcontenttype };

参数
start 可选
开始索引,可以为负数,语法类似于数组的slice方法.默认值为0.
end 可选
结束索引,可以为负数,语法类似于数组的slice方法.默认值为最后一个索引.
contenttype 可选
新的blob对象的mime类型,这个值将会成为新的blob对象的type属性的值,默认为一个空字符串.
返回值
一个新的blob对象,包含了源blob对象中指定范围内的数据.
注意
如果start参数的值比源blob对象的size属性的值还大,则返回的blob对象的size值为0,也就是不包含任何数据.

blobpropertybag

一个包含有两个属性type和endings的对象.
type
设置该blob对象的type属性.
endings(已废弃)
对应于blobbuilder.append()方法的endings参数.该参数的值可以是”transparent”或者”native”.
blob构造函数用法举例

下面的代码:

css code
复制内容到剪贴板

varafileparts=[“<aid=\”a\”><bid=\”b\”>hey!<\/b><\/a>”]; varomyblob=newblob(afileparts,{“type”:“text\/xml”});//theblob


等价于:

css code
复制内容到剪贴板

varobuilder=newblobbuilder(); varafileparts=[“<aid=\”a\”><bid=\”b\”>hey!<\/b><\/a>”]; obuilder.append(afileparts[0]); varomyblob=obuilder.getblob(“text\/xml”);//theblob


blobbuilder接口提供了另外一种创建blob对象的方式,但该方式现在已经废弃,所以不应该再使用了.

例子:使用类型数组和blob对象创建一个对象url

css code
复制内容到剪贴板

vartypedarray=getthetypedarraysomehow(); varblob=newblob([typedarray],{type:“application/octet-binary”});//传入一个合适的mime类型 varurl=url.createobjecturl(blob); Asian Beautiful picture //会产生一个类似blob:d3958f5c-0777-0845-9dcf-2cb28783acaf这样的url字符串 //你可以像使用一个普通url那样使用它,比如用在img.src上.

本文发布于:2023-04-06 14:18:50,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/9663017209c6232c6a8aa38812640d35.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:深入解析HTML5中的Blob对象的使用.doc

本文 PDF 下载地址:深入解析HTML5中的Blob对象的使用.pdf

标签:对象   剪贴板   参数   类型
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图