JavaScript中操作二进制数据的方法_javascript高级

JavaScript通过ArrayBuffer、TypedArray和DataView实现二进制数据操作:ArrayBuffer为固定长度的原始二进制数据缓冲区,需通过视图访问;TypedArray(如Uint8Array、Float32Array)提供带类型的数据视图,适用于图像、音频等场景;DataView支持手动指定字节序的灵活读写,适合协议解析。实际应用包括文件读取、WebSocket通信、Canvas图像处理及音视频流操作,三者协同实现高效二进制处理。

javascript中操作二进制数据的方法_javascript高级

JavaScript中操作二进制数据的能力在处理文件、网络通信、图像音频处理等场景中非常关键。虽然JavaScript最初是为网页脚本设计的,但随着Node.js和Web API的发展,它已经具备了完整的二进制数据处理能力。

1. ArrayBuffer:二进制数据的容器

ArrayBuffer 是用于表示通用、固定长度的原始二进制数据缓冲区的类型。它本身不能直接操作数据,必须通过视图(如 TypedArray 或 DataView)来读写。

创建一个8字节的缓冲区:

const buffer = new ArrayBuffer(8);

此时 buffer 只是一块内存空间,没有具体的解释方式。

立即学习“Java免费学习笔记(深入)”;

2. TypedArray:带类型的数组视图

TypedArray 提供了以特定数据类型访问 ArrayBuffer 的方式,比如 Int8Array、Uint8Array、Float32Array 等。

示例:使用 Uint8Array 操作字节

const buffer = new ArrayBuffer(8);
const view = new Uint8Array(buffer);
view[0] = 42;
console.log(view[0]); // 42

常见类型:

Int8Array:8位有符号整数 Uint8Array:8位无符号整数 Uint16Array:16位无符号整数(自动处理字节序) Float32Array:32位浮点数 Float64Array:64位浮点数

这些视图让开发者能按需解析二进制数据,常用于图像像素、音频样本等处理。

3. DataView:灵活的二进制数据读写

DataView 提供了更底层、更灵活的方式来读写 ArrayBuffer 中的数据,支持手动指定字节序(大端或小端)。

示例:混合读取不同类型的数据

const buffer = new ArrayBuffer(8);
const dataView = new DataView(buffer);
dataView.setUint16(0, 255, true); // 偏移0,写入16位数,true表示小端
dataView.setFloat32(2, 3.14, true); // 偏移2,写入32位浮点数
console.log(dataView.getUint16(0, true)); // 255
console.log(dataView.getFloat32(2, true)); // 3.14

DataView 特别适合处理协议数据包、文件头等需要精确控制字节顺序的场景。

4. 实际应用场景

前端或Node.js中,常见的二进制操作包括:

读取文件(File API):用户上传的文件可通过 FileReader 读成 ArrayBuffer WebSocket 通信:发送和接收 binary 数据时常用 ArrayBuffer 或 Blob Canvas 图像处理:getImageData 返回 ImageData,其数据是 Uint8ClampedArray 音视频处理:Web Audio API 和 MediaRecorder 输出二进制流

示例:从文件读取 ArrayBuffer

const fileInput = document.getElementById(‘file’);
fileInput.addEventListener(‘change’, (e) => {
  const file = e.target.files[0];
  const reader = new FileReader();
  reader.onload = function() {
    const arrayBuffer = reader.result;
    const uint8Array = new Uint8Array(arrayBuffer);
    console.log(uint8Array);
  };
  reader.readAsArrayBuffer(file);
});

基本上就这些。掌握 ArrayBuffer、TypedArray 和 DataView,就能应对大多数二进制数据操作需求。关键是理解它们之间的关系:ArrayBuffer 是数据容器,TypedArray 提供类型化视图,DataView 提供灵活读写。不复杂但容易忽略细节,比如字节序和内存对齐。

以上就是JavaScript中操作二进制数据的方法_javascript高级的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1535306.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月21日 02:19:22
下一篇 2025年12月21日 02:19:40

相关推荐

  • HTML 打开空文档

    使用 html 创建空文档很简单:使用文本编辑器新建一个文本文件。输入 html 代码: 空文档将文件保存为 .html 扩展名(例如 “my_empty_document.html”)。在浏览器中打开文件,你将看到一个空白页面,标题显示为 “空文档”…

    2025年12月22日
    000
  • 巧用 HTML 对齐技巧,让文字美观大方

    html 提供多种对齐选项,以改善网页上的文本美观和可读性:水平对齐:使用 text-align 属性,可左对齐、居中对齐或右对齐文本。垂直对齐:使用 vertical-align 属性,可垂直对齐文本,如与基线、顶部、中间或底部对齐。浮动对齐:使用 float 属性,可将元素向左或向右浮动,从而调…

    2025年12月22日
    000
  • HTML 与 CSS 联动全解析

    html 和 css 联动可创建交互式且用户友好的 web 页面,通过使用 html 定义页面结构,再用 css 样式化、布局。联动步骤如下:使用 标签将 css 链接到 html 文档。使用选择器在 css 中选择特定的 html 元素。应用样式属性来设置文本、颜色、边框等。 HTML 与 CSS…

    2025年12月22日
    000
  • 优化文本框对齐:让你的表单更美观

    通过使用 css 和 javascript,可以优化文本框对齐方式,提升表单的可读性和用户体验。具体优化方法包括:使用 css text-align 和 vertical-align 属性进行水平和垂直对齐。使用 javascript setselectionrange 和 getcomputeds…

    2025年12月22日
    000
  • HTML 段落间距加两格

    此代码可用于导入必备库来刮取和解析 web 数据,并将其导入数据库:使用 python 请求库获取 web 页面。使用 beautifulsoup 库解析页面并提取所需数据。使用 sqlite3 库建立数据库连接并创建表。将提取的数据写入数据库表中。提交更改并关闭数据库连接。 使用 Python 和…

    2025年12月22日
    000
  • 轻松打开微信 HTML 文件

    如何轻松打开微信 html 文件?使用文件传输助手:分享 html 文件并选择“文件传输助手”选择“我的电脑”并点击“打开”使用第三方应用:安装 html 查看器应用点击“打开”按钮并选择 html 文件 轻松打开微信 HTML 文件 微信是一款广受欢迎的即时通讯软件,但有时候我们需要打开微信中的 …

    2025年12月22日
    000
  • HTML 文档中的空白页面

    空白 html 页面的原因包括:缺少根元素、标题元素、语法错误、无法加载资源、浏览器缓存问题。解决方法包括:添加根元素、标题元素、检查语法错误、确保外部资源加载正常、刷新浏览器缓存。例如,通过添加根元素和标题元素,可以解决 index.html 文件显示空白的问题。 HTML 文档中的空白页面:如何…

    2025年12月22日
    000
  • HTML 段落自动缩进两空格

    使用 python 和 beautifulsoup 解析 html 文档的方法如下:加载 html 文档并创建 beautifulsoup 对象。使用 beautifulsoup 对象查找和处理标签元素,如:查找特定标签:soup.find(tag_name)查找所有特定标签:soup.find_a…

    2025年12月22日
    000
  • 前端面试官常问的问题:如何优化网页加载速度?

    优化网页加载速度一直是前端开发中至关重要的一环。在面试中,面试官常常会问到关于网页加载速度优化的问题,因为这不仅考察了面试者对前端性能优化的理解程度,还能体现出其解决问题的能力和实践经验。以下是关于如何优化网页加载速度的一些常见方法和技巧,供大家参考。 一、减少 HTTP 请求 合并文件:将多个 C…

    2025年12月22日
    000
  • 前端面试官常问的问题:如何实现前端路由?

    前端面试官常问的问题:如何实现前端路由? 前端开发是近年来蓬勃发展的领域,技术的不断更新也让前端开发人员面临着更多的挑战与机遇。在前端开发面试中,前端路由是一个经常被问及的话题之一。实现前端路由是前端开发中的一项基础工作,掌握前端路由的原理和实现方式对于提升开发效率和用户体验至关重要。 一、什么是前…

    2025年12月22日
    000
  • 不同维度看前端与后端开发

    前端与后端开发是现代软件开发领域中两个重要的方向,它们各自担负着不同的职责和任务,在项目中密切合作,共同构建出一个完整的应用程序。然而,从不同的维度来看前端和后端开发,会呈现出不同的特点和挑战。本文将从技术层面、团队协作以及职业发展等方面,探讨前端与后端开发之间的异同处。 首先,从技术层面来看,前端…

    2025年12月22日
    000
  • 前端工程师职责解析:主要做什么工作?

    前端工程师职责解析:主要做什么工作? 随着互联网的快速发展,前端工程师作为一个非常重要的职业角色,扮演着连接用户与网站应用程序的桥梁,起着至关重要的作用。那么,前端工程师主要做些什么工作呢?本文将对前端工程师的职责进行解析,让我们来一探究竟。 一、前端工程师的基本职责 网站开发与维护:前端工程师负责…

    2025年12月22日
    000
  • 前端与后端的差异:你了解吗?

    前端与后端的差异:你了解吗? 在当今数字化时代,互联网技术已经深刻地改变了我们的生活方式和工作方式。作为互联网技术的两个重要组成部分,前端和后端在网站和应用程序的开发中扮演着至关重要的角色。但是,很多人对于前端和后端之间的差异并不是很清楚。本文将深入探讨前端与后端的区别,帮助读者更好地了解它们之间的…

    2025年12月22日
    000
  • 探秘前端工程师的日常工作内容

    探秘前端工程师的日常工作内容 随着互联网的快速发展,前端工程师这个职业逐渐走进大众视野。他们承担着网站和应用程序界面开发、优化以及用户体验改进等重要任务,是连接用户与互联网技术的桥梁。那么,究竟前端工程师的日常工作内容是什么呢?让我们一起来探秘。 与设计团队合作前端工程师的工作通常从与设计团队的沟通…

    2025年12月22日
    000
  • 深入了解前端和后端的区别

    前端和后端是软件开发中两个非常重要的概念,它们分别负责不同的功能和任务。在互联网时代,前端和后端的区分已经变得十分明显,而深入了解它们之间的区别对于想要从事软件开发的人来说是非常重要的。 前端,顾名思义就是软件的前端部分,也称为客户端。它是与用户直接交互的界面,包括网页的布局、设计、交互操作、内容展…

    2025年12月22日
    000
  • 什么是前端模块化ESM?

    前端ESM是什么,需要具体代码示例 在前端开发中,ESM是指ECMAScript Modules,即基于ECMAScript规范的模块化开发方式。ESM带来了许多好处,比如更好的代码组织、模块间的隔离和可重用性等。本文将介绍ESM的基本概念和用法,并提供一些具体的代码示例。 ESM的基本概念在ESM…

    2025年12月22日
    000
  • 前端输出设置

    前端output配置,需要具体代码示例 前端开发中,output配置是一项非常重要的配置。它用于定义项目打包后生成的文件路径、文件名以及相关的资源路径等。本文将介绍前端output配置的作用、常用配置选项,并给出具体的代码示例。 output配置的作用:output配置项用于指定项目打包后生成的文件…

    2025年12月22日
    000
  • 深入解析前端网站性能优化模式:提升用户体验流畅度

    在当今互联网发展日新月异的时代,前端网站的性能优化越来越受到重视。随着移动互联网的普及和网站内容的增加,用户对网站性能的要求也越来越高。因此,对于前端开发人员而言,学习和应用网站性能优化模式是至关重要的。 一、加载速度优化 压缩文件:将网站的HTML、CSS和JavaScript文件进行压缩,减少其…

    2025年12月22日
    000
  • 了解canvas的JS技术:你熟知哪些呢?

    探究canvas的JS技术:你知道有哪些吗? 简介 在现代Web开发中,JavaScript已经成为不可或缺的一部分。作为一种脚本语言,它可以为网页添加交互性和动态性。而在JS技术中,canvas则是一个重要的API之一。本文将带您深入了解canvas的JS技术,并介绍一些常用的canvas相关功能…

    2025年12月21日
    000
  • JavaScript快速入门:获取HTTP状态码

    快速入门:使用JavaScript获取HTTP状态码,需要具体代码示例 引言:在开发Web应用程序时,我们经常需要与服务器进行交互并获取HTTP状态码。HTTP状态码是服务器响应请求时返回的一个三位数字,它们提供了对请求状态的基本诊断和信息。在本文中,我们将学习如何使用JavaScript获取HTT…

    2025年12月21日
    000

发表回复

登录后才能评论
关注微信