ArrayBuffer和TypedArray,以及Blob的使用

本文介绍如何在前端使用TypedArray和ArrayBuffer编辑二进制数据,包括将file类型的input选择的文件转化为二进制进行编辑,以及blob数据的读取和转化方法。

阅读目录

回到顶部

  前端使用TypedArray编辑二进制

  ES6提供了, ArrayBuffer和TypedArray, 让前端也可以直接操作编辑二进制数据, 网页中的类型为file的input标签, 也可以通过FileReader转化为二进制, 然后再做编辑等, 本文提供参考;

  ArrayBuffer : 代表内存之中的一段二进制数据, 通过它我们可以直接创建二进制对象,然后使用相关的方法和属性。

  如何使用ArrayBuffer:

  new ArrayBuffer(32), 从内存中申请32个字节;

  把ArrayBuffer转换为可以编辑的TypedArray, 然后修改typedArray的内容, 接着再把二进制的数据转化为blob类型的数据,再把blob对象转化为一个url数据, 接着就可以把blob文件下载下来:

运行下面代码

复制代码

var ab = new ArrayBuffer(32)
var iA = new Int8Array(ab)
iA[0] = 97;//把二进制的数据的首位改为97 ,97为小写字母a的ascll码;
var blob = new Blob([iA], {type: "application/octet-binary"});//把二进制的码转化为blob类型
var url = URL.createObjectURL(blob);
window.open(url)

复制代码

  网站上类型为file的input如果选择了文件, 那么input的value其实就继承了Blob数据,测试demo:

运行下面代码

复制代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    <input type="file" id="f">
    <script>
        var eF = document.getElementById("f");
        eF.onchange = function() {
            var file = eF.files[0];
            console.log(file instanceof Blob)
        }
    </script>
</body>
</html>

复制代码

回到顶部

  FileReader读区blob文件

  我们也可以使用FileReader读取blob数据,并打印出来:

运行下面代码

复制代码

var ab = new ArrayBuffer(32)
var iA = new Int8Array(ab)
iA[0] = 97
var blob = new Blob([iA], {type: "application/octet-binary"});
var fr = new FileReader();
fr.addEventListener("load", function(ev) {
    console.log(ev.target.result);//会输出字符:a
});
fr.readAsText(blob)

复制代码

回到顶部

  blob转化为typedArray

  如果要把blob文件转化为二进制的数据的话,要先把blob转化为arraybuffer,然后再使用typedArray就可以直接编辑二进制数据了:

运行下面代码

复制代码

var ab = new ArrayBuffer(32)
var iA = new Int8Array(ab)
iA[0] = 97
var blob = new Blob([iA], {type: "application/octet-binary"});
var fr = new FileReader();
fr.addEventListener("load", function(ev) {
    var abb = ev.target.result;
    var iAA = new Int8Array(abb);
    console.log(iAA);
});
//把blob文件转化为arraybuffer;
fr.readAsArrayBuffer(blob)

复制代码

  arraybuffer -->> typedarray -->> blob -->> blob通过FileReader转化为 arraybuffer或者text文本或者base64字符串;

  arraybuffer和typedarray主要是处理二进制, 如果要把blob往二进制转换, 必须先把blob转换为arraybuffer, 然后再转换为可以编辑的typedArray;

  实际上, 还有一种比较常用的数据类型, base64编码的数据, 常用的比如image的base64的编码, 文本的base64编码等, 也可以把base64的编码转化为对应的ascll码,再转化为typearray ,然后再生成blob对象:

运行下面代码

复制代码

function dataURLtoBlob(dataurl) {
    var arr = dataurl.split(','), mime = arr[0].match(/:(.*?);/)[1],
    bstr = atob(arr[1]), n = bstr.length, u8arr = new Uint8Array(n);
    //通过atob把base64转化为ascll码, 然后再把ascll码转化为字节码
    while(n--){
      u8arr[n] = bstr.charCodeAt(n);
    }
  //u8arr就是2进制的数据
  return new Blob([u8arr], {type:mime});
} 
### Blob ArrayBuffer 的区别 Blob ArrayBuffer 都是用来处理二进制数据的工具,但在功能用途上存在显著差异。 #### 数据可变性 - **ArrayBuffer** 是一种可变的二进制数据缓冲区。它的内容可以通过 `TypedArray` 或 `DataView` 进行修改[^1]。 - **Blob** 则是一个不可变的对象,一旦创建便无法更改其内部数据[^4]。 #### 存储形式 - **ArrayBuffer** 表示一块固定的内存区域,适合存储原始的二进制数据。它不直接支持文件的操作,而是依赖于视图对象(如 `Uint8Array` 或 `DataView`)来访问操作数据[^5]。 - **Blob** 主要用于表示类文件的数据结构,可以包含一个或多个 `ArrayBuffer` 对象或其他二进制数据片段,并允许设置 MIME 类型其他元信息[^3]。 #### 字节顺序控制 当使用 `DataView` 操作 `ArrayBuffer` 时,可以选择不同的字节顺序(小端或大端),这在跨平台通信中尤为重要[^2]。而 Blob 并未提供类似的低级接口。 --- ### 使用场景对比 #### ArrayBuffer 的典型应用 - **底层硬件交互**:例如与 GPU 或外部设备交换二进制数据。 - **高性能计算**:通过 `SharedArrayBuffer` 实现多线程间的高效共享内存。 ```javascript // 创建并填充一个 ArrayBuffer const buffer = new ArrayBuffer(8); const view = new DataView(buffer); view.setUint16(0, 257, true); // 设置一个小端字节序的无符号短整数 console.log(view.getUint16(0, true)); // 输出 257 ``` #### Blob 的典型应用 - **文件上传/下载**:将图片、视频等内容作为文件流发送到服务器或保存本地。 - **多媒体处理**:生成动态资源链接以便嵌入 HTML 页面。 ```javascript // 创建一个 Blob 并生成 URL const blob = new Blob(['hello world'], { type: 'text/plain' }); const url = URL.createObjectURL(blob); document.querySelector('a').href = url; document.querySelector('a').download = 'example.txt'; document.querySelector('a').textContent = 'Download Text File'; ``` --- ### 总结 - 如果需要灵活地操作二进制数据,则应优先考虑使用 **ArrayBuffer** 及其关联视图。 - 若目标是管理大型文件或者模拟文件行为,则更适合采用 **Blob** 来完成任务。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值