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博客)来完美解决异步问题