Js的Blob/File/ArrayBuffer/FileReader的详解

文章详细介绍了前端JavaScript中处理二进制数据的几个关键对象:File用于获取文件信息并连接DOM,继承自Blob;Blob表示二进制大对象,可用于存储和传输数据;ArrayBuffer是低级别的二进制数据容器,常用于处理字节流;FileReader用于异步读取文件内容。此外,文中还讨论了不同的文件下载方法及其优缺点。
摘要由CSDN通过智能技术生成

在这里插入图片描述

一、File

通过File接口可获取到文件的相关信息,让网页的JS可读取到。File是继承Blob,Blob是它的原型对象。是前端JS特有的对象。
构造函数:定义
在这里插入图片描述

属性:name、size、type(MIME类型)、lastModified、lastModifiedDate等等
在这里插入图片描述

二、Blob

Binary large Object 二进制大对象,不是前端特有的对象,是计算机通用术语
不可变、原始数据的类文件。一个只读的二进制文件,不可进行操作的
构造函数 :定义
在这里插入图片描述
属性: name、type
方法 :arrayBuffer()、slice()、stream()、text()
在这里插入图片描述
例子如下所示:
其中slice方法可实现分割文件,分片上传
在这里插入图片描述

三、ArrayBuffer

从XHR、文件API、Canvas读取了字节流,直接拿JS的Array去存,浪费又低效。
ArrayBuffer就是为了增强JS的二进制处理能力。
ArrayBuffer就是一片内存,表示原始数据二进制的缓存区。
是无法直接操作它,需要借助TypedArray(类数组)和DataView(数据视图)对象来读写它。它们会将缓冲区的内容表示为特定的格式,并通过这些格式来读取缓冲区的内容
在这里插入图片描述

四、区别和联系

1 、File和Blob

File是DOM接口和文件的一座桥梁,将其联系起来
File继承于Blob,是特殊的Blob,拥有Blob的属性和方法,又多了几个自己独有的属性。
File是前端JS特有的对象,Blob是计算机通用术语

2、Blob和ArrayBuffer

ArrayBuffer更底层,是一段纯粹内存上的二进制数据,可借助TypedArray(类数组)和DataView(数据视图)对象来读写它,对某段数据进行操作它
Blob就是对二进制数据做了一层封装,拿到的是一个整体,可以看到整体的属性大小、类型,可以进行分割,但却看不到其内部的细节
Blob更易于传输

五、FileReader

异步读取用户存储在计算机的文件(或原始数据缓存区)的内容
在这里插入图片描述
** 方法 **
在这里插入图片描述

六、文件下载

1、通过a标签

不足之处:只能做get请求,url长度有限制;跨域限制;无法在header中携带token做鉴权操作;无法判断是否获取成功

2、window.open下载

不足之处:pdf、png、jpg等文件会直接打开预览;url长度限制;url编码问题;无法在header中携带token做鉴权操作;无法判断是否获取成功

3、location.href下载(可下载大文件)

不足之处 :pdf、png、jpg等文件会直接打开预览;url长度限制;url编码问题;无法在header中携带token做鉴权操作;无法判断是否获取成功

4、文件流传blob对象下载

不足之处 :兼容问题(IE10);需等文件流全部获取才会开始下载

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript中的BlobFile和Base64都是处理文件或数据的常用对象。下面将介绍它们的使用场景以及相互之间的转换。 Blob对象用于表示不能被修改的类文件数据,并且可以在被发送到服务器之前进行处理。它可用于在网页上生成和下载文件,比如将网页上的图片存储为Blob对象,然后使用URL.createObjectURL()方法将其显示为图像。此外,Blob对象也可以用于通过XMLHttpRequest或Fetch API将数据发送到服务器。 File对象继承自Blob对象,它是用户在表单中选择的文件的表示形式。File对象可以包含文件的名称、大小、类型以及最后修改日期等信息。在上传文件时,我们通常会使用File对象来获取文件的详细信息并进行验证。 Base64是一种将二进制数据编码为ASCII字符的方式,常用于在文本传输中表示二进制数据。我们可以使用JavaScript的btoa()和atob()函数在Base64字符串和二进制数据之间进行相互转换。 在相互转换方面,可以将Blob对象转换为Base64字符串,然后使用toDataURL()方法将其转换为DataURL,或者使用FileReader对象的readAsDataURL()方法将BlobFile对象转换为DataURL。而将Base64字符串转换为Blob对象,则可以使用Blob构造函数并设置正确的MIME类型。 综上所述,Blob对象适用于处理类文件数据和发送到服务器,File对象适用于处理用户上传的文件,而Base64适用于在文本传输中表示二进制数据。根据具体的应用场景和需求,我们可以进行这三种对象之间的相互转换。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值