当前位置: 首页 > news >正文

ArrayBuffer 对象常见的几个用途

ArrayBuffer 在 JavaScript 中的用途广泛,主要用于处理二进制数据。
ArrayBuffer 对象、 TypedArray 视图和 DataView 视图是 JavaScript 操作二进制数据的一个接口。本文介绍ArrayBuffer 对象的常见的一些用法。

1. 网络传输二进制数据

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

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 接口读取本地文件的二进制内容。

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 等。

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 中的多种数值类型。

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 用于存储将要渲染到网页上的数据。

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 来存储音频信号。

// 假设 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 构造函数的参数之一。

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 和类型化数组代替普通数组,以优化内存使用和处理速度。

var arrayBuffer = new ArrayBuffer(1024);
var float32View = new Float32Array(arrayBuffer);// 性能优化的数据处理
for (var i = 0; i < float32View.length; i++) {float32View[i] = i * 1.5;
}
http://www.lryc.cn/news/391806.html

相关文章:

  • STC89C52RC单片机设计的FM收音机+自动搜台+存储电台(程序+原理图+PCB)
  • 【若依】关闭当前标签页并跳转路由到其他页面
  • 防爆智能手机如何解决危险环境下通信难题?
  • 软件测试最全面试题及答案整理(2024最新版)
  • 11 - matlab m_map地学绘图工具基础函数 - 绘制航迹、椭圆、风向玫瑰图和特定的圆形区域的有关函数及其用法
  • 长安链安装及使用问题
  • 大学生竞赛管理系统-计算机毕业设计源码37276
  • 去中心化 RAG 先行者,KIP Protocol 如何保护数据所有权、激活 AI 资产
  • numpy库(python)
  • AI技术在招聘行业的应用
  • 代谢组数据分析(十二):岭回归、Lasso回归、弹性网络回归构建预测模型
  • 顺序表(C语言详细版)
  • 【Linux】Linux常用指令合集精讲,一篇让你彻底掌握(万字真言)
  • zerotier-one自建根服务器方法五
  • 掌握MySQL基础命令:主键与外键常用的命令与操作
  • K8S之网络深度剖析(一)(持续更新ing)
  • Land survey boundary report (template)
  • [数据集][目标检测]婴儿状态睡觉哭泣检测数据集VOC+YOLO格式7109张3类别
  • 深入解析 MySQL 的 SHOW FULL PROCESSLIST
  • IPsec连接 和 SSL连接
  • Redis【超详细】
  • 通过ip获取用户位置信息以及地区时间
  • pytest-yaml-sanmu(七):使用fixture返回值
  • 2024最全软件测试面试八股文(答案+文档+视频讲解)
  • EasyBoss ERP移动端上线数据分析模块,随时查Shopee/TikTok本土店数据
  • 机器学习与AI大数据的融合:开启智能新时代
  • 视频监控业务平台LntonCVS国标视频综合管理平台功能及技术优势
  • Python面试宝典第6题:有效的括号
  • Windows上使用Navicat连接ubuntu上的mysql8报错:10061和1130
  • Feign远程调用,请求头丢失情况