Blob初探
简介
Blob在js中意味着二进制大数据。实现该接口的对象有3个属性,分别是type(MIME),size(byte)和
一个切割方法:slice(在大文件分片上传可能用到)。另外,File实现了Blob接口,并且还有额外的属性--name和
lastModify。
早起的一些浏览器实现了草案(已废弃)上的BlobBuilder,但是现在的大多浏览器废弃了该对象。目前,创建新的
Blob对象需要使用Blob构造函数,new Blob(array,type)。第一个参数数组中可以包含字符串,ArrayBuffer对象或者
一个Blob对象。
现对比这两种方式:
// 构造函数创建
var ab = new ArrayBuffer(8);
var dv = new DataView(ab);
for(var i=0;i<8;i++) dv.setInt8(i,i);
var arr = ["yang li is tanGer's husband;",ab];
var b = new Blob(arr,{type: "application/octet-binary"});
console.log(b, b.type)
------------------------------------------------------------------------------
var bb = new BlobBuilder();
bb.append("yang li is tanGer's husband;")
bb.append("\0");
var ab = new ArrayBuffer(8);
var dv = new DateView(ab);
for(var i=0;i<8;i++) dv.setInt8(i,i);
bb.append(ab);
var ret = bb.getBlob("x-op\/mytype")
console.log(ret,ret.type);
可以讲blob作为参数,创建Blob URL,它是对内存或者磁盘上Blob对象的一个引用。而Data URL则是
对文件内容进行URL编码,其本身就是数据。另外,在创建Blob URL之后,浏览器便维护URL与内存或者磁盘Blob
之间的映射,Blob对象及时已经没有用处也不会被释放,因为始终有Blob URL在引用。故,需要手动的将Blob URL删除。
可通过FileReader对Blob读取,fileReader对象可监听多个事件,比较有用的是onload和onprocess。FileReader读取
Blob数据是异步进行的,可以用4种方式读取,常用的两种分别读取为文本和ArrayBuffer。
但是在web Worker中可以同步运行类似的构造方法:FileReaderSync。worker同步运行该方法并不会影响当前的主线程。
下面demo实现了一个拖动图片显示的功能:
<style>
.active{background: 1px firebrick;}
.droptarget{border:3px solid royalblue;width:400px;height:400px;margin: auto;float:left;}
</style>
--------------------------------------------------------------------------
<div class="droptarget" id="droptarget"></div>
<div style="float:left;margin-left:20px;" id="show"></div>
--------------------------------------------------------------------------
var createUrl = URL && URL.createObjectURL ||
window.webkitURL && window.webkitURL.createObjectURL ||
window.createObjectURL;
var revokeUrl = URL && URL.revokeObjectURL ||
window.webkitURL && window.webkitURL.revokeObjectURL ||
window.revokeObjectURL;
function $(id){return document.getElementById(id)} $("droptarget").ondragenter = function(e){
var dt = e.dataTransfer;
//过滤文件
if(dt.types && dt.types.indexOf("Files") != -1){
this.classList.add("active");
}
return false;
}
$("droptarget").ondragleave = function(e){
this.classList.remove("active");
};
$("droptarget").ondragover = function(e){
return false;
}
$("droptarget").ondrop = function(e){
e.preventDefault();
var dt = e.dataTransfer;
var files,i,len,f;
var img,show = $("show");
files = dt.files;
for(i=0,len=files.length;i<len;i++){
f = files[i];
if(f.type.indexOf("image/") == -1) return;
img = new Image();
img.style.width = "400px";
img.src = createUrl(f);
img.onload = function(e){
show.innerHTML = "";
show.appendChild(img);
revokeUrl(img.src); // 手动删除Blob URL
}
}
this.classList.remove("active")
return false;
} // 可以使用FileReader异步对Blob对象的数据进行修改
function read(blob){
var r = new FileReader();
r.readAsText(blob); // 异步读取
r.onload = function(e){
var d = r.result;
}
r.onerror = function(e){
console.log("error happens...")
}
r.onprogress = function(e){
$("droptarget").innerText = e.loaded + "/" + e.total;
}
}
Blob初探的更多相关文章
- 初探JavaScript PDF blob转换为Word docx方法
PDF转WORD为什么是历史难题 PDF 转Word 是一个非常非常普遍的需求,可谓人人忌危,为什么如此普遍的需求,却如此难行呢,还得看为什么会有这样的一个需求: PDF文档遵循iOS32000的规范 ...
- React Native初探
前言 很久之前就想研究React Native了,但是一直没有落地的机会,我一直认为一个技术要有落地的场景才有研究的意义,刚好最近迎来了新的APP,在可控的范围内,我们可以在上面做任何想做的事情. P ...
- Weex 初探
Weex 初探 Weex 介绍 Weex 是阿里于 2016 年开源的一款开发框架,它的介绍是: Weex 是一个使用 Web 开发体验来开发高性能原生应用的框架. 它使用了 Web 技术来开发 An ...
- 从壹开始前后端分离【 .NET Core2.0 +Vue2.0 】框架之九 || 依赖注入IoC学习 + AOP界面编程初探
更新 1.如果看不懂本文,或者比较困难,先别着急问问题,我单写了一个关于依赖注入的小Demo,可以下载看看,多思考思考注入的原理: https://github.com/anjoy8/BlogArti ...
- Python3+unitest自动化测试初探(中篇)
目录 6.生成测试报告 7.编写邮件发送工具 8.发送邮件 发布 0 86 编辑 删除 Python3+unitest自动化测试初探(中篇)(2019-04-18 01:41) 发布 3 245 编辑 ...
- Mycat 中间件配置初探与入门操作
Mycat中间件配置初探与入门操作 By:授客 QQ:1033553122 实践环境 Mycat-server-1.5.1-RELEASE-20161130213509-win.tar.gz 下载地址 ...
- braft初探
接上一篇<brpc初探>. 什么是RAFT 看内部一个开源项目的时候,一开始我以为他们自己实现了raft协议.但是看了代码之后,发现用的是braft.因为在我们自己bg里一直在提paxos ...
- Git 内部原理--初探 .git
说到Git大家应该都非常熟悉,几乎每天都会用到它.在日常使用过程中,我们貌似并不需要关注其内部的原理,只需要记住那几个常用的命令,就可以说自己是会Git的人了.可是,事实真的是这样子的吗?今天我们就来 ...
- 微信小程序之文件系统初探
微信小程序之文件系统初探 1.文件下载 //下载文件 go_download: function() { var content = this; var baseUrl = "http:// ...
随机推荐
- Django开发笔记
django基础之视图 1.在Django中网页前端的页面和其他内容都是由视图来传递的(视图对web请求进行回应)Django通过检查请求的URL(准确地说,是URL里域名之后的那部分)来选择使用哪个 ...
- python之路 - 爬虫
网络爬虫(又被称为网页蜘蛛,网络机器人,在FOAF社区中间,更经常的称为网页追逐者),是一种按照一定的规则,自动地抓取万维网信息的程序或者脚本.另外一些不常使用的名字还有蚂蚁.自动索引.模拟程序或者蠕 ...
- java并发编程(十六)happen-before规则
转载请注明出处:http://blog.csdn.net/ns_code/article/details/17348313 happen-before规则介绍 Java语言中有一个"先行发生 ...
- CSS外边距叠加问题
CSS外边距叠加就是margin-collapse,边距合并指的是,当两个垂直外边距相遇时,它们将形成一个外边距,水平边 距永远不会重合.重叠结果计算规则:①.两个相邻的外边距都是正数时,折叠结果是它 ...
- java包(package)的命名规范
Java的包名都有小写单词组成,类名首字母大写:包的路径符合所开发的 系统模块的 定义,比如生产对生产,物资对物资,基础类对基础类.以便看了包名就明白是哪个模块,从而直接到对应包里找相应的实现. 由 ...
- spring mvc + ehcache 利用注解实现缓存功能
我的spring是3.1的,因为项目需求,需要在查询时候加上缓存,小白一个,完全没有用过缓存(ehcache),摸索了一天终于会了一点通过注解来使用ehcache进行缓存,立刻给记录下来. 首先 我的 ...
- Centos 6.5 部署 redmine 3.3
验证ruby版本 如果有就卸载安装最新的 yum install gcc* openssl openssl-devel -y wget https://ruby.taobao.org/mirrors/ ...
- innerHTML on ie6-9
https://msdn.microsoft.com/en-us/library/ms533897(VS.85).aspx The innerHTML property is read-only on ...
- 第一章-第十四题(Hello world程序)
题目:请找一个同学结对 (参看本书结对编程的内容),两人共同工作 (不能分开干活),从上面的列表中选取两个平台,在每个平台上,写一个最简单的 "Hello World" 类型的程序 ...
- 玩转JavaScript OOP[0]——基础类型
前言 long long ago,大家普遍地认为JavaScript就是做一些网页特效的.处理一些事件的.我身边有一些老顽固的.NET程序员仍然停留在这种认知上,他们觉得没有后端开发肯定是构建不了系统 ...