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;
}
相关推荐
潇凝子潇14 分钟前
使用英伟达免费调用多家大模型API
java·前端·javascript
旷世奇才李先生27 分钟前
Vue 3\+Vite\+Pinia实战:前端工程化与组件化开发全指南
前端·vue.js
Beginner x_u31 分钟前
前端八股整理(手写 01)|Promise 超时控制、红绿灯与 Promise.all
前端·javascript·promise
万少10 小时前
Vibe Coding不停歇,移动端 TRAE SOLO 让你用手机也能编程啦
前端·javascript·后端
kyriewen1110 小时前
WebAssembly:前端界的“外挂”,让C++代码在浏览器里跑起来
开发语言·前端·javascript·c++·单元测试·ecmascript
烛衔溟11 小时前
TypeScript 接口的基本使用 —— 定义对象形状
前端·javascript·typescript
铁皮饭盒12 小时前
成为AI全栈 - 第3课:路由 RESTful Elysia 状态码 设计规范
前端·后端·全栈
顾昂_12 小时前
Web 性能优化完全指南
前端·面试·性能优化
IT乐手12 小时前
Claude Code + Qwen 的配置方法
javascript·claude
前端程序媛-Tian13 小时前
前端 AI 提效实战:从 0 到 1 打造团队专属 AI 代码评审工具
前端·人工智能·ai