FileReader

Posted 程序大白兔

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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博客)来完美解决异步问题

FileReader基础

FileReader语法

例子

属性

FileReader.error表示在读文件操作过程中发生的错误
FileReader.readyState表示FileReader读取数据的状态,有三个值:

  • EMPTY:没有数据被加载

  • LOADING:数据正在被加载

  • LOADING:数据正在被加载

FileReader.result代表数据读取完成后的结果,只有在数据被加载完成后,result属性才有效。

事件

FileReader.onbortFileReaderreading操作被中断的时候触发。
FileReader.onerrorFileReader读取数据过程中发生错误时触发
FileReader.onloadFileReader读取事件完成后调用
FileReader.onloadstartFileReader读取事件开始时调用
FileReader.onloadendFileReader读事件完成后调用
FileReader.onprogressFileReader读取数据的过程中调用

方法

FileReader.abort()中断读数据操作,直接返回,readyState将被设置为DONE
FileReader.readAsArrayBuffer()读取Blob类型的数据,读取完成后返回ArrayBuffer对象,ArrayBuffer对象存储数据内容。
FileReader.readAsBinaryString()读取一个Blob对象,将Blob对象中的原始二进制数据作为字符串的形式返回。
FileReader.readAsDataURL()返回一个代表文件数据的URL
FileReader.readAsTextString()读取一个Blob对象,返回一个文本字符串。

Demo

一个拖拽事件的demo,参考MDN

<!DOCTYPE html>
<html>
    <head>
        <title>文件拖拽</title>
        <style type="text/css" rel="stylesheet">
            *{
                margin:0 auto;
            }
            html,body{
                width:100%;
                height:100%;
            }
            #container{
                width:100%;
                height:100%;
                display:flex;
                display:-webkit-flex;
                justify-content:center;
                align-items:center;
                flex-direction:columns;
            }
            #child{
                border:2px solid;
                width:400px;
                height:200px;
            }
            input{
                width:200px;
                height:40px;
                margin-top:20px;
                margin-left:10px;
            }
            p{
                width:20px;
                width:40px;
                margin-left:10px;
                margin-top:20px;
            }
            a{
                display:inline-block;
                height:30px;
                width:200px;
                margin-top:20px;
                margin-left:10px;
            }
        </style>
        
    </head>
    <body>
        <div id="container">
            <div id="child">
                <h3>实现拖拽</h3>
                <input id="nfiles" type="file"  multiple/>
                <p id="showfilesize">Size:</p>
            </div>
        </div>

        <script type="text/javascript">
            var pElement = document.getElementById(‘showfilesize‘);
            var fileInputElement=document.getElementById(‘nfiles‘);
            function change(files){
                var nLen = files.length,nFile,nBytes=0,sOut=‘‘,middleSize;
                for(var i=0;i<nLen;i++){
                    nFile=files[i];
                    nBytes+=nFile.size;
                }
                sOut=nBytes+"bytes";
                for(var unitIndex=0,units=["KiB", "MiB", "GiB", "TiB", "PiB", "EiB", "ZiB", "YiB"],middleSize=nBytes;middleSize/=1000,middleSize>1;unitIndex++){
                    sOut=middleSize.toFixed(3)+units[unitIndex]+"("+nBytes+"byte"+")";
                }
                pElement.innerHTML=‘size:‘+sOut;
            }
            //监听拖拽事件
            fileInputElement.addEventListener(‘dragenter‘,dragEnter,false);
            fileInputElement.addEventListener(‘dragover‘,dragOver,false);
            fileInputElement.addEventListener(‘drop‘,drop,false);
            function dragEnter(e){
                e.stopPropagation();
                e.preventDefault();
            }
            function dragOver(e){
                e.stopPropagation();
                e.preventDefault();
            }
            function drop(e){
                e.stopPropagation();
                e.preventDefault();
                var dt=e.dataTransfer;
                var files=dt.files;
                change(files);
            }
        </script>
    </body>
</html>

本文转载于:猿2048?https://www.mk2048.com/blog/blog.php?id=ha2jkc20icb

以上是关于FileReader的主要内容,如果未能解决你的问题,请参考以下文章

将大文件切成块并使用 ajax 和 html5 FileReader 上传

使用js-xlsx库,前端读取Excel报表文件

前端input<File;读取本地文本文件 | FileReader

移动前端—图片压缩上传实践

js图片前端预览之 filereader 和 window.URL.createObjectURL

招贤纳士--前端开发工程师