返回顶部
首页 > 资讯 > 精选 >HTML5中FileReader对象怎么用
  • 498
分享到

HTML5中FileReader对象怎么用

2023-06-09 11:06:38 498人浏览 独家记忆
摘要

这篇文章主要介绍HTML5中FileReader对象怎么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!写在前面前一篇文章介绍了html5中的Blob对象(详情戳这里),从中了解到Blob对象只是二进制数据的容器,本

这篇文章主要介绍HTML5中FileReader对象怎么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

写在前面

前一篇文章介绍了html5中的Blob对象(详情戳这里),从中了解到Blob对象只是二进制数据的容器,本身并不能操作二进制,故本篇将对其操作对象FileReader进行介绍。

FileReader

FileReader主要用于将文件内容读入内存,通过一系列异步接口,可以在主线程中访问本地文件。

使用FileReader对象,WEB应用程序可以异步的读取存储在用户计算机上的文件(或者原始数据缓冲)内容,可以使用File对象或者Blob对象来指定所要处理的文件或数据。

创建实例

var reader = new FileReader();

方法

方法定义描述
abort():void终止文件读取操作
readAsArrayBuffer(file):void异步按字节读取文件内容,结果用ArrayBuffer对象表示
readAsBinaryString(file):void异步按字节读取文件内容,结果为文件的二进制串
readAsDataURL(file):void异步读取文件内容,结果用data:url的字符串形式表示
readAsText(file,encoding):void异步按字符读取文件内容,结果用字符串形式表示

事件

事件名称描述
onabort当读取操作被中止时调用
onerror当读取操作发生错误时调用
onload当读取操作成功完成时调用
onloadend当读取操作完成时调用,不管是成功还是失败
onloadstart当读取操作将要开始之前调用
onprogress在读取数据过程中周期性调用

使用方法

FileReader通过异步的方式读取文件内容,结果均是通过事件回调获取,下面是一个读取本地txt文件内容的例子:

var input  = document.getElementById("file"); //input fileinput.onchange = function(){    var file = this.files[0];    if(!!file){        //读取本地文件,以gbk编码方式输出        var reader = new FileReader();        reader.readAsText(file,"gbk");        reader.onload = function(){            //读取完毕后输出结果            console.log(this.result);        }    }}

此外我们还可以通过注册onprogress、onerror等事件,记录文件读取进度或异常行为等等。

读取方式

FileReader提供了四种不同的读取文件的方式,如:readAsArrayBuffer会将文件内容读取为ArrayBuffer对象,readAsBinaryString则将文件读取为二进制串,下面对这四种方式进行简单区分。

首先准备一张图片(6764 字节)和一个txt文本(51字节)作为测试文件:

HTML5中FileReader对象怎么用

接着编写测试代码:

 var reader = new FileReader();// 通过四种方式读取文件//reader.readAsXXX(file);   reader.onload = function(){    //查看文件输出内容    console.log(this.result);    //查看文件内容字节大小    console.log(new Blob([this.result]))}

readAsDataURL

查看图片输出结果:

HTML5中FileReader对象怎么用

查看txt输出结果:

HTML5中FileReader对象怎么用

很明显,readAsDataURL会将文件内容进行base64编码后输出,这个很好区分。

readAsText

此方法可以通过不同的编码方式读取字符,我们使用utf-8读取

查看图片输出结果:

HTML5中FileReader对象怎么用

查看txt输出结果:

HTML5中FileReader对象怎么用

readAsText读取文件的单位是字符,故对于文本文件,只要按规定的编码方式读取即可;
而对于媒体文件(图片、音频、视频),其内部组成并不是按字符排列,故采用readAsText读取,会产生乱码,同时也不是最理想的读取文件的方式

readAsBinaryString

查看图片输出结果:

HTML5中FileReader对象怎么用

查看txt输出结果:

HTML5中FileReader对象怎么用

与readAsText不同的是,readAsBinaryString函数会按字节读取文件内容。
然而诸如0101的二进制数据只能被机器识别,若想对外可见,还是需要进行一次编码,而readAsBinaryString的结果就是读取二进制并编码后的内容。
尽管readAsBinaryString方法可以按字节读取文件,但由于读取后的内容被编码为字符,大小会受到影响,故不适合直接传输,也不推荐使用。
如:测试的图片文件原大小为6764 字节,而通过readAsBinaryString读取后,内容被扩充到10092个字节

readAsArrayBuffer

查看图片输出结果:

HTML5中FileReader对象怎么用

查看txt输出结果:

HTML5中FileReader对象怎么用

与readAsBinaryString类似,readAsArrayBuffer方法会按字节读取文件内容,并转换为ArrayBuffer对象。
我们可以关注下文件读取后大小,与原文件大小一致。
这也就是readAsArrayBuffer与readAsBinaryString方法的区别,readAsArrayBuffer读取文件后,会在内存中创建一个ArrayBuffer对象(二进制缓冲区),将二进制数据存放在其中。通过此方式,我们可以直接在网络中传输二进制内容。
好了说这么多,那ArrayBuffer到底是个毛?
关于ArrayBuffer对象牵涉的知识点比较多,完全可以单开一篇细说,在此只要简单理解为存放了一段二进制数据的内存空间即可。
而本身ArrayBuffer中的内容对外是不可见的,若要查看其中的内容,就要引入另一个概念:类型化数组
我们可以尝试查看下刚刚通过readAsArrayBuffer方法读取的图片文件内容:

HTML5中FileReader对象怎么用

可以看到,整个图片文件的6764个字节,被分别存储在长度为6764的数组中,而数组中每一个元素的值,为当前字节的十进制数值。
关于ArrayBuffer和类型化数组的概念在此不做深入解释,之后会再写一篇单独讨论。

应用场景

说了这么多,最后还是要落实到FileReader能解决什么问题,下面通过几个例子说明:

在线预览本地文件

我们知道,img的src属性或background的url属性,可以通过被赋值为图片网络地址或base64的方式显示图片。
在文件上传中,我们一般会先将本地文件上传到服务器,上传成功后,由后台返回图片的网络地址再在前端显示。
通过FileReader的readAsDataURL方法,我们可以不经过后台,直接将本地图片显示在页面上。这样做可以减少前后端频繁的交互过程,减少服务器端无用的图片资源,代码如下:

var input  = document.getElementById("file");   // input fileinput.onchange = function(){    var file = this.files[0];        if(!!file){            var reader = new FileReader();            // 图片文件转换为base64            reader.readAsDataURL(file);            reader.onload = function(){                // 显示图片                document.getElementById("file_img").src = this.result;        }    }}

运行效果如下:

HTML5中FileReader对象怎么用

对于图片上传,我们也可以先将图片转换为base64进行传输,此时由于传输的图片内容就是一段字符串,故上传接口可以当做普通post接口处理,当图片传输到后台后,可以在转换为文件实体存储。
当然,考虑到base64转换效率及其本身的大小,本方法还是适合于上传内容简单或所占内存较小的文件。

二进制数据上传

HTML5体系的建立引入了一大堆新的东西,基于XHR2,我们可以直接上传或下载二进制内容,无需像以往一样通过fORM标签由后端拉取二进制内容。
简单整理下上传逻辑:
1、通过input[type="file"]标签获取本地文件File对象
2、通过FileReader的readAsArrayBuffer方法将File对象转换为ArrayBuffer
3、创建xhr对象,配置请求信息
4、通过xhr.sendAsBinary直接将文件的ArrayBuffer内容装填至post body后发送
代码实现如下:

var input  = document.getElementById("file");   // input fileinput.onchange = function(){    var file = this.files[0];        if(!!file){            var reader = new FileReader();            reader.readAsArrayBuffer(file);            reader.onload = function(){                var binary = this.result;                upload(binary);        }    }}//文件上传function upload(binary){    var xhr = new XMLHttpRequest();    xhr.open("POST", "http://xxxx/opload");    xhr.overrideMimeType("application/octet-stream");    //直接发送二进制数据    if(xhr.sendAsBinary){        xhr.sendAsBinary(binary);    }else{        xhr.send(binary);    }        // 监听变化    xhr.onreadystatechange = function(e){        if(xhr.readyState===4){            if(xhr.status===200){                // 响应成功                   }        }    }}

以上是“HTML5中FileReader对象怎么用”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网精选频道!

--结束END--

本文标题: HTML5中FileReader对象怎么用

本文链接: https://lsjlt.com/news/255735.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • HTML5中FileReader对象怎么用
    这篇文章主要介绍HTML5中FileReader对象怎么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!写在前面前一篇文章介绍了HTML5中的Blob对象(详情戳这里),从中了解到Blob对象只是二进制数据的容器,本...
    99+
    2023-06-09
  • HTML5中sessionStorage对象有什么用
    这篇文章将为大家详细讲解有关HTML5中sessionStorage对象有什么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。HTML5 sessionStorage会话...
    99+
    2024-04-02
  • Html5 中怎么利用FileReader实现即时上传图片功能
    Html5 中怎么利用FileReader实现即时上传图片功能,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。<!DOCT...
    99+
    2024-04-02
  • html5中返回AudioTrackList对象的属性audioTracks怎么用
    小编给大家分享一下html5中返回AudioTrackList对象的属性audioTracks怎么用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!实例获得可用音轨的数量:myVid=doc...
    99+
    2024-04-02
  • html5中返回TimeRanges对象的属性buffered怎么用
    小编给大家分享一下html5中返回TimeRanges对象的属性buffered怎么用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!实例获得视频的第一段缓冲范围(部分),以秒计:myVid...
    99+
    2024-04-02
  • HTML5中的Blob对象如何使用
    本篇内容主要讲解“HTML5中的Blob对象如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“HTML5中的Blob对象如何使用”吧! HTML5中的Bl...
    99+
    2024-04-02
  • 如何在HTML5中使用json对象
    这期内容当中小编将会给大家带来有关如何在HTML5中使用json对象,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。具体代码如下所示:<!DOCTYPE html><html&g...
    99+
    2023-06-09
  • 如何在HTML5中使用Blob对象
    这篇文章将为大家详细讲解有关如何在HTML5中使用Blob对象,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。html有什么特点1、简易性:超级文本标记语言版本升级采用超集方式,从而更加灵活方...
    99+
    2023-06-09
  • html5中返回一个MediaError对象的属性error怎么用
    这篇文章给大家分享的是有关html5中返回一个MediaError对象的属性error怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。实例获得视频的错误状态:myVid=do...
    99+
    2024-04-02
  • HTML5中的Blob对象的使用方法
    这篇文章将为大家详细讲解有关HTML5中的Blob对象的使用方法,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。HTML5中的Blob对象和MYSQL中的BL...
    99+
    2024-04-02
  • js中对象怎么用
    这篇文章给大家分享的是有关js中对象怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。对象1 使用解构删除不必要属性有时候你不希望保留某些对象属性,也许是因为它们包含敏感信息或...
    99+
    2024-04-02
  • 如何使用HTML5的localStorage对象
    这篇文章主要讲解了“如何使用HTML5的localStorage对象”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用HTML5的localStorag...
    99+
    2024-04-02
  • HTML5中dataTransfer对象的示例分析
    这篇文章将为大家详细讲解有关HTML5中dataTransfer对象的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。HTML5拖拽的数据传输  虽然通过drags...
    99+
    2024-04-02
  • JavaScript中Math对象怎么用
    这篇文章主要介绍了JavaScript中Math对象怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。Math对象属性:Math对象方法:...
    99+
    2024-04-02
  • Node.js中Buffer对象怎么用
    小编给大家分享一下Node.js中Buffer对象怎么用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!Buffer 是 Node.js 的内置类型,它是用来表示内存中一块区域的,用以保存二...
    99+
    2024-04-02
  • ADO.NET中SqlCommand对象怎么用
    小编给大家分享一下ADO.NET中SqlCommand对象怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!ADO.NET经过长时间的发展,很多用户都很了解AD...
    99+
    2023-06-17
  • html5中怎么将图片的绝对路径转换成文件对象
    这篇文章将为大家详细讲解有关html5中怎么将图片的绝对路径转换成文件对象,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。具体如下:我们先来理解基本知识点:1. 理解HTML5中的FileList对象与fi...
    99+
    2023-06-09
  • python scrapy框架中Request对象和Response对象怎么用
    本篇内容介绍了“python scrapy框架中Request对象和Response对象怎么用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!...
    99+
    2023-06-29
  • Java中JSP的session对象和config对象怎么使用
    本篇内容主要讲解“Java中JSP的session对象和config对象怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java中JSP的session对象和config对象怎么使用”吧!...
    99+
    2023-07-04
  • Java中JSP的pageContext对象和page对象怎么使用
    这篇文章主要讲解了“Java中JSP的pageContext对象和page对象怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java中JSP的pageContext对象和page对象...
    99+
    2023-07-05
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作