js二进制数据及其互相转化实现

本文详细介绍了JavaScript中二进制数据的处理,包括File、Blob、ArrayBuffer和Base64之间的相互转化方法,适合前端开发者学习如何在文件操作和数据传输中有效利用这些数据类型。
摘要由CSDN通过智能技术生成

本文主要为大家介绍了js二进制数据及其互相转化实现详解,有需要的朋友可以借鉴参考下,希望能够有所帮助。

file

在js中有很多二进制数据,有file,base64,Blob,ArrayBuffer,FileReader。这些二进制数据在文件导出和下载的时候是经常会用到的,我们这篇文章就是介绍这些二进制数据以及它们之间的转化。

文件(File)接口提供有关文件的信息,并允许网页中的 JavaScript 访问其内容。实际上,File 对象是特殊类型的 Blob,且可以用在任意的 Blob 类型的 context 中。Blob 的属性和方法都可以用于 File 对象。

file文件

file文件一般有两种来源

  • <input> 元素上选择文件后返回的 FileList 对象;
  • 文件拖放操作生成的 DataTransfer 对象;

每个 File 对象都包含以下属性,这些属性都继承自 Blob 对象:

  • lastModified:引用文件最后修改日期,为自1970年1月1日0:00以来的毫秒数;
  • lastModifiedDate:引用文件的最后修改日期;
  • name:引用文件的文件名;
  • size:引用文件的文件大小;
  • type:文件的媒体类型(MIME);
  • webkitRelativePath:文件的路径或 URL。

base64

Base64 是一种基于64个可打印字符来表示二进制数据的表示方法。Base64 编码普遍应用于需要通过被设计为处理文本数据的媒介上储存和传输二进制数据而需要编码该二进制数据的场景。这样是为了保证数据的完整并且不用在传输过程中修改这些数据。

Blob

Blob 对象表示一个不可变、原始数据的类文件对象。它的数据可以按文本或二进制的格式进行读取,也可以转换成 ReadableStream 来用于数据操作。

也就是说blob对象是原始二进制数据对象,是不可修改的。

blob的用法

1

new Blob(array, options);

array:由 ArrayBufferArrayBufferViewBlobDOMString 等对象构成的,

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将一个Android Bitmap对象转化二进制数据,可以使用Bitmap类的compress()方法。具体的步骤如下: 1. 创建一个ByteArrayOutputStream对象。 2. 调用Bitmap对象的compress()方法,将Bitmap对象压缩为指定格式的二进制数据,并将结果输出到ByteArrayOutputStream对象中。 3. 调用ByteArrayOutputStream对象的toByteArray()方法,将ByteArrayOutputStream对象中的二进制数据转化为byte数组。 以下是一个示例代码: ```java Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.bitmap); ByteArrayOutputStream baos = new ByteArrayOutputStream(); bitmap.compress(Bitmap.CompressFormat.PNG, 100, baos); byte[] imageBytes = baos.toByteArray(); ``` 在上面的代码中,我们首先使用BitmapFactory类的decodeResource()方法,从资源文件中获取一个Bitmap对象。然后创建一个ByteArrayOutputStream对象,调用Bitmap对象的compress()方法,将Bitmap对象压缩为PNG格式的二进制数据,并将结果输出到ByteArrayOutputStream对象中。最后使用ByteArrayOutputStream对象的toByteArray()方法,将ByteArrayOutputStream对象中的二进制数据转化为byte数组。 注意,这里我们将Bitmap对象压缩为PNG格式的二进制数据,你可以根据需要将其压缩为其他格式,比如JPEG。另外,compress()方法中的第二个参数表示压缩质量,取值范围为0-100,数值越高表示压缩质量越好,但文件大小也越大。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值