• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >html5 > 深入解析HTML5中的Blob对象的使用_html5教程技巧

深入解析HTML5中的Blob对象的使用_html5教程技巧

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-03

本文主要包含HTML,Blob等相关知识,匿名希望在学习及工作中可以帮助到您
HTML5中的Blob对象和MYSQL中的BLOB类型在概念上是有点区别的。MYSQL中的BLOB类型就只是个二进制数据容器。而HTML5中的Blob对象除了存放二进制数据外还可以设置这个数据的MINE类型,这相当于对文件的储存,其它很多二进制对象也是从这个对象继承的。
  在稍低版本的现代浏览器中,这个Blob对象还没规范化,因此需要BlobBuilder之类的方式来创建。但是现在Blob已经规范到可以直接new它的构造器Blob来创建了,而且浏览器几乎都已经支持了这个方式,所以对于旧标准咱就没必要纠结了。

  1. var data='次碳酸钴';
  2. var blob=new Blob([data],{"type":"text/html"});
  3. console.log(blob);

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

  1. var data='次碳酸钴';
  2. var blob=new Blob([data],{"type":"text/html"});
  3. onload=function(){
  4. var iframe=document.createElement("iframe");
  5. iframe.src=URL.createObjectURL(blob);
  6. document.body.appendChild(iframe);
  7. };

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

方法

slice()

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

  1. Blob slice(
  2. optional long long start,
  3. optional long long end,
  4. optional DOMString contentType
  5. };

参数
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构造函数用法举例

下面的代码:

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


等价于:

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


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

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

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

您可能想查找下面的文章:

  • HTML5知识点总结
  • HTML5的本地存储
  • HTML5本地存储之IndexedDB
  • Html5实现文件异步上传功能
  • Html5新标签datalist实现输入框与后台数据库数据的动态匹配
  • 详解HTML5 window.postMessage与跨域
  • HTML5拖放API实现拖放排序的实例代码
  • 解决html5中video标签无法播放mp4问题的办法
  • HTML5新特性 多线程(Worker SharedWorker)
  • Html5新增标签有哪些

相关文章

  • 2017-08-06HTML5实现WebSocket协议原理浅析
  • 2017-08-06HTML5 Video/Audio播放本地文件示例介绍
  • 2017-08-06HTML5 canvas基本绘图之图形变换
  • 2018-12-03如何使用 CSS3 实现 TeX 一般强大的行内元素排版?
  • 2017-08-06HTML5 transform三维立方体实现360无死角三维旋转效果
  • 2018-12-03HTML5的音频和视频监听器的应用代码详解
  • 2017-08-06HTML5新增的8类INPUT输入类型介绍
  • 2018-12-03《实用技巧》—让你的网站变成响应式的3个简单步骤
  • 2018-12-03建站的主要流程?
  • 2018-12-03HTML5优势到底有哪些?

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • 介绍几个超炫酷的HTML5动画演示及源码的图文详解
    • H5缓存机制浅析 移动端Web加载性能优化
    • HTML5响应式banner
    • LESS-Middleware:Node.js 和 LESS 的完美搭配
    • 为何说 HTML5「no longer based on SGML」?
    • 作为一个前端工程师,是往node方面转,还是往HTML5方面转?
    • 分享一个简单的HTML5 视频嵌入实例代码
    • HTML5游戏框架cnGameJS开发实录-外部输入模块篇
    • html5桌面通知(Web Notifications)实例解析_html5教程技巧
    • HTML 5应用程序缓存使用总结

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有