本文摘自PHP中文网,作者黄舟,侵删。
FileReader是File-API重要的组成部分用于读取本地文件
FileReader
创建
要想使用读取文件功能
同样需要实例化FileReader对象
1 |
|
它为我们提供了一些接口方法和事件
方法
通过实例对象可以调用5个方法
其中4个指定文件读取方式
另1种方法用来中断文件读取
API | 参数 | 描述 |
---|---|---|
FileReader.readAsBinaryString | File/Blob | 文件读取为二进制字符串,每字节包含一个0到255之间的整数 |
FileReader.readAsText | File/Blob[,encoding] | 文件读取为文本字符串。默认文本编码格式是’UTF-8’,可通过可选参数指定为其他编码格式 |
FileReader.readAsDataURL | File/Blob | 文件读取为一个基于Base64编码的Data-URI对象 |
FileReader.readAsArrayBuffer | File/Blob | 文件读取为一个ArrayBuffer对象 |
abort() | 无 | 终止文件读取 |
注:Blob(Binary Large Object)是二进制对象
无论文件读取成功与否
这些函数不会有任何返回值
读取的文件结果存储于实例化的FileReader对象的result属性中
事件
文件读取对象中除了上面的方法之外
还包含一套完整的事件模型
用于捕获在文件读取的各个状态
onloadstart : 开始读取
onprogress : 正在读取
onload : 读取成功
onerror : 读取错误
onabort : 读取中断
onloadend : 读取完成(无论成败)
使用
现在我们使用这个Filereader来读取一个本地图像
html如下
简单创建了一个文件读取按钮input
和一个用来显示所读取图片的img标签
1 |
|
js脚本如下
1 2 3 4 5 6 7 8 9 10 |
|
获取节点后
为input标签绑定change事件
这样当每次选择文件后,就会调用showImg函数进行读取
验证读取内容可以检查file.type
1 2 3 4 |
|
或者如果想要读取文字
就是用readAsText
1 |
|
1 2 3 4 5 6 7 8 9 10 11 |
|
文件读取模块
为了更好的处理文件读取
我们需要封装一个文件读取模块
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 |
|
以上就是具体解析HTML5文件读取FileReader及文件读取模块的封装的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
更多相关阅读请进入《HTML5》频道 >>

Vue.js 设计与实现 基于Vue.js 3 深入解析Vue.js 设计细节
本书对 Vue.js 3 技术细节的分析非常可靠,对于需要深入理解 Vue.js 3 的用户会有很大的帮助。——尤雨溪,Vue.js作者