JS中ArrayBuffer、Uint8Array、Blob与文本字符之间的相互转换
前端 File
上传、下载,Canvas
保存图片,Ajax
和 Fetch
二进制流传输,PDF
预览,浏览器上 WebAssembly
的应用 等等都需要用到 ArrayBuffer 和 Blob 。文件就具体介绍一下这些对象的相互转换。
API介绍
FileReader
对象允许Web应用程序异步读取存储在用户计算机上的文件(或原始数据缓冲区)的内容,使用File
或Blob
对象指定要读取的文件或数据。Blob
对象表示一个不可变、原始数据的类文件对象。它的数据可以按文本或二进制的格式进行读取,也可以转换成ReadableStream
来用于数据操作。Blob
表示的不一定是JavaScript
原生格式的数据。File
接口基于Blob
,继承了blob
的功能并将其扩展使其支持用户系统上的文件。ArrayBuffer
对象代表储存二进制数据的一段内存,它不能直接读写,只能通过视图(TypedArray
视图和DataView
视图)来读写,视图的作用是以指定格式解读二进制数据。Uint8Array
对象是ArrayBuffer
的一个数据类型(8 位不带符号整数)。TextEncoder
接受代码点流作为输入,并提供UTF-8
字节流作为输出。TextDecoder
接口表示一个文本解码器,一个解码器只支持一种特定文本编码,例如 utf-8、iso-8859-2、koi8、cp1261,gbk 等等。解码器将字节流作为输入,并提供代码点流作为输出。
注意: 二进制数组并不是真正的数组,而是类似数组的对象。
字符与ArrayBuffer,Uint8Array相互转换
TextEncoder
=>ArrayBuffer
let encoder = new TextEncoder(); // 字符 转 Uint8Array let uint8Array = encoder.encode("你好啊"); // Uint8Array 转 ArrayBuffer let arrayBuffer = uint8Array.buffer
Blob
=>ArrayBuffer
let str = 'hello,你好吗?' let blob = new Blob([str],{type:'text/plain;charset=utf-8'}); let utf8decoder = new TextDecoder() blob.arrayBuffer().then(buffer=>{ // ArrayBuffer console.log(buffer) let text = utf8decoder.decode(buffer) // String console.log(text) })
FileReader
=>ArrayBuffer
let str = 'hello,你好吗?' let blob = new Blob([str],{type:'text/plain;charset=utf-8'}); let utf8decoder = new TextDecoder() let fr = new FileReader() fr.readAsArrayBuffer(blob) fr.onload = function(res) { // ArrayBuffer let buffer = fr.result console.log(buffer) let text = utf8decoder.decode(buffer) // String console.log(text) }
欢迎访问:天问博客
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】博客园2025新款「AI繁忙」系列T恤上架,前往周边小店选购
【推荐】凌霞软件回馈社区,携手博客园推出1Panel与Halo联合会员
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· C# 14 新增功能一览,你觉得实用吗?
· C#/.NET/.NET Core优秀项目和框架2025年4月简报
· Java的"伪泛型"变"真泛型"后,会对性能有帮助吗?
· .NET + AI | Semantic Kernel vs Microsoft.Extension
· 用AI开发AI翻译助手:初学者也能轻松做出第一个应用