JavaScript File API和Blob API

文章介绍了File对象的属性,如name、size、type和lastModifiedDate,以及如何通过监听change事件获取文件信息。同时,详细讲解了FileReader如何异步读取文件,包括readAsText、readAsDataURL、readAsBinaryString和readAsArrayBuffer等方法,用于灵活处理文件数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、File类型

每个file对象都有一些只读属性。

  • name: 本地系统中的文件名。
  • size:以字节计的文件大小。
  • type:包含文件 MIME 类型的字符串。
  • lastModifiedDate:表示文件最后修改时间的字符串。这个属性只有 Chome 实现了。

例如,通过监听 change 事件然后遍历 files 集合可以取得每个选中文件的信息:

let filesList = document.getElementById("files-list"); 
filesList.addEventListener("change", (event) => { 
 let files = event.target.files, 
 i = 0, 
 len = files.length; 
 while (i < len) { 
 const f = files[i]; 
 console.log(`${f.name} (${f.type}, ${f.size} bytes)`); 
 i++; 
 } 
}); 

File API 还提供了 FileReader 类型,让我们可以实际从文件中读取数据。

2、FileReader 类型

FileReader类型表示一种异步文件读取机制。可以把FileReader 想象成类似于XMLHttpRequest,
只不过是用于从文件系统读取文件,而不是从服务器读取数据。FileReader 类型提供了几个读取文件
数据的方法。

  • readAsText(file, encoding):从文件中读取纯文本内容并保存在 result 属性中。第二个
    参数表示编码,是可选的。
  • readAsDataURL(file):读取文件并将内容的数据 URI 保存在 result 属性中。
  • readAsBinaryString(file):读取文件并将每个字符的二进制数据保存在 result 属性中。
  • readAsArrayBuffer(file):读取文件并将文件内容以 ArrayBuffer 形式保存在 result 属性。

这些读取数据的方法为处理文件数据提供了极大的灵活性。例如,为了向用户显示图片,可以将图
片读取为数据 URI,而为了解析文件内容,可以将文件读取为文本。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值