首页 > 其他分享 >JS 中的二进制 - Blob 与 ArrayBuffer

JS 中的二进制 - Blob 与 ArrayBuffer

时间:2024-02-21 16:22:25浏览次数:35  
标签:DataView 二进制 ArrayBuffer JavaScript JS Blob 数组

零、参考资料

  1. 《图解 + 实战》File、Blob、TypedArray、DataView
  2. JavaScript也有操作二进制的一天:聊ArrayBuffer和Blob
  3. 聊聊JS的二进制家族:Blob、ArrayBuffer和Buffer

一、定义

  • 宏观:Blob - 表示一个不可变、原始数据的类文件对象,可读不可写
  • 微观:ArrayBuffer - 表示通用的原始二进制数据缓冲区,可读不可写

二、Blob

这个对象被设计出来就是为了方便进行文件的操作,所以看定义,是一个"原始数据"、"类文件"对象。   Blob 对象"不可变",其中的数据可以按照文本或者二进制格式进行读取;但是我们可以转换成 ReadableStream 去进行数据操作(进行操作的对象和原对象基本没啥关系了)。   Blob 对象一个重要的 slice 方法,其作用是将一个大 Blob 分割为多个小 Blob,这也是 FE 能实现分段上传文件的核心 API。   File 对象则是一个特殊的 Blob 对象,是基于用户的操作系统拓展的 Blob,使用户可以通过浏览器安全的访问系统的本地文件。  

三、ArrayBuffer、TypedArray 和 DataView

(一)由来

为了充分利用 3D 图形 API 和 GPU 加速在 canvas 上渲染复杂图形,出现了WebGL(Web Graphics Library)。但因为 JavaScript 运行时中的数组并不存在类型,所以当WebGL底层与 JavaScript 之间传递数据时,需要为目标环境分配新数组,并以当前格式迭代,这将花费很多时间。
为了解决这个问题,则出现了定型数组(TypeArray)。通过定型数组 JavaScript 可以分配、读取、写入数组,并直接传给底层图形驱动程序,也可直接从底层获取。
既然定型数组赋予 JavaScript 跟底层进行数据交换的能力,那么就同样会出现与其他设备/网络进行二进制数据的交流,应对更复杂的场景,DataView 也应运而生。
他们以数组的语法处理二进制数据,所以统称为二进制数组,TypedArray 和 DataView 可以像C语言一样通过修改下标的方式直接操作内存  

(二)ArrayBuffer

ArrayBuffer对象用来表示通用的、固定长度的原始数据缓冲区,是一个普通的 JavaScript 构造函数,可用于内存中分配特定数量的字节空间。ArrayBuffer 存储原始的二进制数据,本身是可读不可写的,只是一个数据容器,所以才有了 TypedArray 与 DataView 去完成写入工作。
const buf = new ArrayBuffer(16) // 在内存中分配16字节

console.log(buf.byteLength) // 16
  ArrayBuffer 和 JavaScript 数组在使用上是完全不同的,有三个区别:
  • ArrayBuffer 初始化后是固定大小的,并且可读不可写;
  • 数组里面可以放数字、字符串、布尔值以及对象和数组等,ArrayBuffer 放0和1组成的二进制数据;
  • ArrayBuffer 放在栈中,而 Array 放在堆中;
 

(三)TypedArray

TypeArray是一个统称,实际使用的是特定元素类型的类型化数组构造函数:类型化数组 - TypedArray。   常用于音视频、canvas、录音,处理网络中接收到的二进制数据,web work 中的大量数据处理场景。

(四)DataView

专为文件 I/O 和网络 I/O 设计,对缓冲数据有高度的控制,但比其他视图性能差一点。跟 TypeArray 不同,DataView 视图中允许存在多种类型。
常用于构建二进制文件或格式化文件。  

 四、总结

(一)Blob 和 ArrayBuffer

  • Blob实际上就是针对文件设计出来的对象,而 ArrayBuffer 针对需要传输的数据本身;
  • Blob主要解决媒体类型(MIME)的问题,ArrayBuffer 解决的是数据类型问题;
  • Blob是浏览器的api,ArrayBuffer 则是 JavaScript 中的标准,ArrayBuffer 是更底层的API,可以直接操作内存;

(二)二进制数组操作场景

  • 与底层显卡/外部设备进行二进制数据交互
  • 利用 SharedArrayBuffer 在不同 worker 间共享内存
  • ...

 五、其他

(一)FileReader

FileReader 对象允许 Web 应用程序异步读取存储在用户计算机上的文件(或原始数据缓冲区)的内容,就 3 个主要方法,完成 Blob/File 到其他不同数据(二进制/string/base64)的转换:
  • readAsArrayBuffer(blob) -> Blob 转换成 ArrayBuffer
  • readAsDataURL(blob) -> Blob 转换成 base64
  • readAsText(blob) -> Blob 转换成 string
   

标签:DataView,二进制,ArrayBuffer,JavaScript,JS,Blob,数组
From: https://www.cnblogs.com/cc-freiheit/p/18025449

相关文章

  • RxJS中高阶映射操作符的全面讲解:switchMap, mergeMap, concatMap (and exhaustMap)
    原文链接:https://blog.angular-university.io/rxjs-higher-order-mapping/有一些在日常开发中常用的RxJS的操作符是高阶操作符:switchMap,mergeMap,concatMap,以及exhaustMap。举个例子,程序中大多数的网络请求都是通过以上某个操作符来完成的,所以为了能够写出几乎所有反应式编程,必须......
  • 利用jszip实现批量文件压缩下载
    介绍前端可以通过一个第三方库jszip,可以把多个文件以blob、base64或纯文本等形式,按自定义的文件结构,压缩成一个zip文件,然后通过浏览器download下来。官网:stuk.github.io/jszip/用法不难,直接看code://先封装一个方法,请求返回文件blobasyncfunctionfetchBlob(fetchUrl,meth......
  • 子页面刷新父页面的操作,jsp那种老项目
    非弹窗页,而是跳转的子页是个新窗口页,要在新窗口页实现刷新父页面的列表getDataByKeys()为父页面自定义的刷新列表方法,在此调用刷新,也可以换成reload(),就是变成刷新整个window窗口页面//刷新父页面的查询functionrefreshParentQuery(){t......
  • js 各种时间格式的转换
    js各种时间格式的转换时间格式 示例中国标准时间 FriMar18202214:24:45GMT+0800(中国标准时间)部分可读字符串 FriMar182022格林威治时间 Fri,18Mar202206:24:45GMT现在用的时间标准UTC FriMar18202206:24:45GMTIOS标准时间(JSON时间格式) 2022-03-18T06:24:45.061Z......
  • js判断checkbox是否被选中
    js判断checkbox是否被选中JavaScript中判断是否选中checkbox有以下几种实现方法:方法一:使用getElementById获取checkbox元素,通过checked属性判断是否被选中。varcheckbox=document.getElementById("myCheckbox");if(checkbox.checked){console.log("checkbox被选中"......
  • python实战:用requests+json抓取接口
    一,安装requests1,用pip安装(venv)liuhongdi@192news%pip3installrequests2,查看所安装库的版本:(venv)liuhongdi@192news%pip3showrequestsName:requestsVersion:2.31.0Summary:PythonHTTPforHumans.Home-page:https://requests.readthedocs.ioAu......
  • js时间戳转换 带时区的格式
    JavaScript中可以使用Date.toLocaleString()函数将时间戳转换为包含时区信息的日期字符串。示例代码如下所示:1//获取当前时间戳(单位:毫秒)2vartimestamp=Date.now();34//创建一个新的Date对象并传入时间戳作为参数5vardateObj=newDate(timestamp);6......
  • three.js 添加 echarts图表
    functioninitChart(){////基于准备好的dom,初始化echarts实例varmyChart=echarts.init($("<canvaswidth='512'height='512'></canvas>")[0]);//绘制图表myChart.setOption({title:{text:'ECharts入门示例'......
  • python实战:使用json序列化
    一,官方文档:https://docs.python.org/zh-cn/3/library/json.html二,json与字典的相互转化1,字典转json字符串1234567importjson #字典转jsond=dict(name='Tom',age=2,score=88)json_d=json.dumps(d)print(type(json_d))print(json_d)......
  • Flask 学习100-Flask-SocketIO 结合 xterm.js 实现网页版Xshell
    前言xterm.js是一个使用TypeScript编写的前端终端组件,可以直接在浏览器中实现一个命令行终端应用。可以实现web-terminal功能,类似于Xshell操作服务器。Flask-SocketIO快速入门与使用基础参考前面这篇https://www.cnblogs.com/yoyoketang/p/18022139前后端交互前端代码......