首页IT科技file文件怎么读取(FileReader)

file文件怎么读取(FileReader)

时间2025-09-18 04:04:19分类IT科技浏览6329
导读:FileReader是一种异步读取文件机制。...

FileReader是一种异步读取文件机制                 。

FileReader提供了如下方法:

readAsArrayBuffer(file):按字节读取文件内容                 ,结果用ArrayBuffer对象表示

readAsBinaryString(file):按字节读取文件内容                         ,结果为文件的二进制串

readAsDataURL(file):读取文件内容        ,结果用data:url的字符串形式表示

readAsText(file,encoding):按字符读取文件内容                 ,结果用字符串形式表示

abort():终止文件读取操作

方法详细:

1.abort

abort方法可以终止任何操作                         ,在读取大文件的时候        ,这个方法能派上用场

示列 

reader.abort();

2.readAsArrayBuffer

readAsArrayBuffer方法读取文件后         ,会在内存中创建一个ArrayBuffer对象(二进制缓冲区)                         ,将二进制数据存放在其中                         。通过此方式                ,可以直接在网络中传输二进制内容        。

示列

var reader = new FileReader(); reader.readAsArrayBuffer(file); reader.onload = function () { console.log(this.result); console.log(new Blob([this.result])) }

3.readAsBinaryString

readAsBinaryString 方法会读取指定的 Blob 或 File 对象,当读取完成的时候         ,readyState 状态会变成DONE(已完成)                          ,并触发 loadend (en-US) 事件                ,同时 result 属性将包含所读取文件原始二进制格式                 。

示列

var reader = new FileReader(); reader.readAsBinaryString(file); reader.onload = function (e) { var arrayBuffer = reader.result; }

4.readAsDataURL

readAsDataURL 方法会读取指定的 Blob 或 File 对象                         。并生成data URl(base64编码)        。

示列

var reader=new FileReader reader.readAsDateURL(file); reader.onload = function (e) { var dataUrl = reader.result; }

 5.readAsText

readAsText方法可以用来读取文本文件,这个文件有两个参数                          ,第一个参数用来读取File对象或Blob对象         。第二个参数用来指定文件的编码                         ,这是个可选参数,默认值为国际通用的UTF-8编码格式                         。

示列

var reader = new FileReader(); reader.readAsText(file); reader.onload = function () { vat txt = reader.result; }

readAsText读取TXT文本文件乱码问题:

之前有过用默认编码方式进行读取TXT文件                 ,会出现中文乱码                         ,后面把reader.readAsText(file,编码)的编码方式改为gb2312’就不乱码了                。

FileReader事件:

onloadstart:读取文件开始时触发

onprogress:读取过程中触发        ,会返还本次读取文件的最大字节数和已经读取完毕的字节数                 ,可以用来做进度条

onabort:在读取中断时触发

onerror:在读取文件失败时触发

onload:在读取完成时触发

onloadend:读取结束后触发                         ,不论成功还是失败都会触发        ,触发时机在onload之后

提示:

因为FileReader的操作都是异步的         ,所以对有些需要同步获取数据的不能实现         。

这里提一个方法                          ,可以用promise队列(链接:promise_程序大白兔的博客-CSDN博客)来完美解决异步问题

创心域SEO版权声明:以上内容作者已申请原创保护,未经允许不得转载,侵权必究!授权事宜、对本内容有异议或投诉,敬请联系网站管理员,我们将尽快回复您,谢谢合作!

展开全文READ MORE
彝古文字(人工智能助力古彝文识别,推动传统文化传承) 新网站如何快速收录(提升网站收录率的秘诀)