ArrayBuffer 对象常见的几个用途

ArrayBuffer 在 JavaScript 中的用途广泛,主要用于处理二进制数据。

ArrayBuffer 对象、 TypedArray 视图和 DataView 视图是 JavaScript 操作二进制数据的一个接口。本文介绍ArrayBuffer 对象的常见的一些用法。

1. 网络传输二进制数据

使用方法:通过 XMLHttpRequest 或 Fetch API 接收二进制数据,设置响应类型为 arraybuffer。

javascript 复制代码
var xhr = new XMLHttpRequest();
xhr.open('GET', 'binary-data.bin', true);
xhr.responseType = 'arraybuffer';

xhr.onload = function() {
    if (xhr.status === 200) {
        var arrayBuffer = xhr.response;
        // 使用 ArrayBuffer
    }
};

xhr.send(null);

2. 文件读取

使用方法:使用 FileReader 接口读取本地文件的二进制内容。

javascript 复制代码
var fileInput = document.querySelector('input[type="file"]');

fileInput.addEventListener('change', function(event) {
    var file = event.target.files[0];
    var reader = new FileReader();

    reader.onload = function(event) {
        var arrayBuffer = event.target.result;
        // 使用 ArrayBuffer 处理文件数据
    };

    reader.readAsArrayBuffer(file);
});

3. 创建类型化数组

使用方法:基于 ArrayBuffer 创建类型化数组,如 Uint8Array、Float32Array 等。

javascript 复制代码
var arrayBuffer = new ArrayBuffer(16); // 创建一个16字节的ArrayBuffer
var uint8View = new Uint8Array(arrayBuffer);

for (var i = 0; i < uint8View.length; i++) {
    uint8View[i] = i;
}

console.log(uint8View); // 输出: Uint8Array(16) [0, 1, 2, ..., 13, 14, 15]

4. 使用 DataView 读写多种数值类型

使用方法:使用 DataView 提供的灵活性来读写 ArrayBuffer 中的多种数值类型。

javascript 复制代码
var buffer = new ArrayBuffer(8);
var view = new DataView(buffer);

// 写入数据
view.setFloat32(0, 3.14, true); // 写入32位浮点数,小端序

// 读取数据
var floatValue = view.getFloat32(0, true); // 读取32位浮点数,小端序
console.log(floatValue); // 输出: 3.14

5. WebGL 中使用

使用方法:在 WebGL 中,ArrayBuffer 用于存储将要渲染到网页上的数据。

javascript 复制代码
var canvas = document.createElement('canvas');
var gl = canvas.getContext('webgl');

var positionBuffer = gl.createBuffer();
gl.bindBuffer(gl.ARRAY_BUFFER, positionBuffer);

var positions = [
    -1, -1,
     1, -1,
     0,  1
];

gl.bufferData(
    gl.ARRAY_BUFFER, 
    new Float32Array(positions), 
    gl.STATIC_DRAW
);

6. Web Audio API

使用方法:处理音频样本数据,创建 ArrayBuffer 来存储音频信号。

javascript 复制代码
// 假设 audioData 是从某个源获取的音频样本数据
var audioData = ...;

var audioContext = new AudioContext();
var arrayBuffer = audioData.toArrayBuffer();

audioContext.decodeAudioData(arrayBuffer, function(buffer) {
    var source = audioContext.createBufferSource();
    source.buffer = buffer;
    source.connect(audioContext.destination);
    source.start();
});

7. Blob 构造

使用方法:ArrayBuffer 可以作为 Blob 构造函数的参数之一。

javascript 复制代码
var arrayBuffer = new ArrayBuffer(10);
var blob = new Blob([arrayBuffer], { type: 'application/octet-stream' });

// 使用 blob,例如通过 URL.createObjectURL 创建一个可下载的链接
var url = URL.createObjectURL(blob);
console.log(url);

8. 性能优化

使用方法:使用 ArrayBuffer 和类型化数组代替普通数组,以优化内存使用和处理速度。

javascript 复制代码
var arrayBuffer = new ArrayBuffer(1024);
var float32View = new Float32Array(arrayBuffer);

// 性能优化的数据处理
for (var i = 0; i < float32View.length; i++) {
    float32View[i] = i * 1.5;
}
相关推荐
万少1 小时前
小龙虾(openclaw),轻松玩转自动发帖
前端·人工智能·后端
Jagger_3 小时前
抱怨到躺床关灯的一次 DIY 记录
前端
陈随易6 小时前
前端大咖mizchi不满Rust、TypeScript却爱上MoonBit
前端·后端·程序员
whinc7 小时前
🚀 两年小程序开发,我把踩过的坑做成了开源 Skills
前端·微信小程序·ai编程
兆子龙8 小时前
ahooks useRequest 深度解析:一个 Hook 搞定所有请求
java·javascript
兆子龙8 小时前
React Suspense 从入门到实战:让异步加载更优雅
java·javascript
sure2828 小时前
React Native中创建自定义渐变色
前端·react native
KKKK9 小时前
SSE(Server-Sent Events)流式传输原理和XStream实践
前端·javascript
子兮曰9 小时前
Humanizer-zh 实战:把 AI 初稿改成“能发布”的技术文章
前端·javascript·后端