最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

具体解析HTML5文件读取FileReader及文件读取模块的封装

来源:懂视网 责编:小采 时间:2020-11-27 15:11:52
文档

具体解析HTML5文件读取FileReader及文件读取模块的封装

具体解析HTML5文件读取FileReader及文件读取模块的封装:FileReader是File-API重要的组成部分 用于读取本地文件FileReader创建要想使用读取文件功能 同样需要实例化FileReader对象var fr = new FileReader();它为我们提供了一些接口方法和事件方法通过实例对象可以调用5个方法 其中4个指定文件读取方式 另1种方
推荐度:
导读具体解析HTML5文件读取FileReader及文件读取模块的封装:FileReader是File-API重要的组成部分 用于读取本地文件FileReader创建要想使用读取文件功能 同样需要实例化FileReader对象var fr = new FileReader();它为我们提供了一些接口方法和事件方法通过实例对象可以调用5个方法 其中4个指定文件读取方式 另1种方
FileReader是File-API重要的组成部分
用于读取本地文件

FileReader

创建

要想使用读取文件功能
同样需要实例化FileReader对象

var fr = new FileReader();

它为我们提供了一些接口方法和事件

方法

通过实例对象可以调用5个方法
其中4个指定文件读取方式
另1种方法用来中断文件读取

API参数描述
FileReader.readAsBinaryStringFile/Blob文件读取为二进制字符串,每字节包含一个0到255之间的整数
FileReader.readAsTextFile/Blob[,encoding]文件读取为文本字符串。默认文本编码格式是’UTF-8’,可通过可选参数指定为其他编码格式
FileReader.readAsDataURLFile/Blob文件读取为一个基于Base64编码的Data-URI对象
FileReader.readAsArrayBufferFile/Blob文件读取为一个ArrayBuffer对象
abort()终止文件读取

注:Blob(Binary Large Object)是二进制对象

无论文件读取成功与否
这些函数不会有任何返回值
读取的文件结果存储于实例化的FileReader对象的result属性中

事件

文件读取对象中除了上面的方法之外
还包含一套完整的事件模型
用于捕获在文件读取的各个状态

  • onloadstart : 开始读取

  • onprogress : 正在读取

  • onload : 读取成功

  • onerror : 读取错误

  • onabort : 读取中断

  • onloadend : 读取完成(无论成败)

  • 使用

    现在我们使用这个Filereader来读取一个本地图像
    html如下
    简单创建了一个文件读取按钮input
    和一个用来显示所读取图片的img标签

    <input type="file" id="choose"><br><br><img src="" id="image" width='200px' height='200px'>


    js脚本如下

    var choose = document.getElementById('choose');var img = document.getElementById('image');
    choose.onchange = function(){
     showImg(this, img);
    }function showImg(chooseDom, imgDom){
     var file = chooseDom.files[0]; //获取FileList对象的第一个元素——一个File对象
     var fr = new FileReader(); //实例化FileReader对象
     fr.onload = function(e){ 
     imgDom.src = e.target.result; //e.target引用fr
     }
     fr.readAsDataURL(file); //读取为DataURL}

    获取节点后
    为input标签绑定change事件
    这样当每次选择文件后,就会调用showImg函数进行读取

    验证读取内容可以检查file.type

    if(!/image\/\w+/.test(file.type)){ 
     //...
     return false; 
    }

    或者如果想要读取文字
    就是用readAsText

    <input type="file" id="choose"><br><br><p id="demo"></p>
    var choose = document.getElementById('choose');
    var demo = document.getElementById('demo');
    choose.onchange = function(){
     showText(this, demo);
    }function showText(chooseDom, textDom){
     var file = chooseDom.files[0]; var fr = new FileReader();
     fr.onload = function(e){
     textDom.innerHTML = e.target.result;
     }
     fr.readAsText(file);
    }

    文件读取模块

    为了更好的处理文件读取
    我们需要封装一个文件读取模块

    //events事件回调对象包含
    success,load,progressvar FileLoader = function (file, events) {
     this.reader = new FileReader(); 
     this.file = file; 
     this.loaded = 0; 
     this.total = file.size; 
     this.step = 1024 * 1024;//每次读取1M
     this.events = events || {}; 
     this.bindEvent(); 
     this.readBlob(0);//读取第一块}
    FileLoader.prototype = {
     bindEvent: function (events) {
     var _this = this,
     reader = this.reader;
     reader.onload = function (e) {
     _this.onLoad();
     };
     reader.onprogress = function (e) {
     _this.onProgress(e.loaded);
     }; // start、abort、error回调暂无
     },
     onProgress: function (loaded) {
     var percent,
     handler = this.events.progress; 
     this.loaded += loaded;
     percent = (this.loaded / this.total) * 100;
     handler && handler(percent);
     }, // 读取结束(每一次执行read结后调用)
     onLoad: function () {
     var handler = this.events.load; 
     // 在此发送读取的数据
     handler && handler(this.reader.result); 
     // 如果未读取完毕继续读取
     if (this.loaded < this.total) { 
     this.readBlob(this.loaded);
     } else { 
     // 读取完毕
     this.loaded = this.total; 
     // 如果有success回调则执行
     this.events.success && this.events.success();
     }
     }, // 读取文件内容
     readBlob: function (start) {
     var blob,
     file = this.file; 
     // 若支持slice方法,则分步读取,不支持就一次性读取
     if (file.slice) {
     blob = file.slice(start, start + this.step + 1);
     } else {
     blob = file;
     } this.reader.readAsText(blob);
     }, 
     // 中止读取
     abort: function () {
     var reader = this.reader; 
     if(reader) {
     reader.abort();
     }
     }
    }

    声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文档

    具体解析HTML5文件读取FileReader及文件读取模块的封装

    具体解析HTML5文件读取FileReader及文件读取模块的封装:FileReader是File-API重要的组成部分 用于读取本地文件FileReader创建要想使用读取文件功能 同样需要实例化FileReader对象var fr = new FileReader();它为我们提供了一些接口方法和事件方法通过实例对象可以调用5个方法 其中4个指定文件读取方式 另1种方
    推荐度:
    标签: 文件 封装 File
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top