近来研究点对点的文件传输,想到一种方案FileReader+WebRtc。
当我看到FileReader的时候,哎呀,不错的东西啊,仔细一看属于File API,或者叫做Web API。
File API 官方的文档 File API
MDN的Web APIs|MDN
MDN的 web引用中使用文件
其主要由,FileList,Blob,File,FileReader等组成。
这里我们主要探讨一下FileReader,先看看官方网站的接口定义
[Constructor, Exposed=Window,Worker]
interface FileReader: EventTarget { // async read methods
void readAsArrayBuffer(Blob blob);
void readAsText(Blob blob, optional DOMString label);
void readAsDataURL(Blob blob); void abort(); // states
const unsigned short EMPTY = ;
const unsigned short LOADING = ;
const unsigned short DONE = ; readonly attribute unsigned short readyState; // File or Blob data
readonly attribute (DOMString or ArrayBuffer)? result; readonly attribute DOMError? error; // event handler attributes
attribute EventHandler onloadstart;
attribute EventHandler onprogress;
attribute EventHandler onload;
attribute EventHandler onabort;
attribute EventHandler onerror;
attribute EventHandler onloadend; };
首先可以看出来,他继承的是EventTarget,这说明什么,哈哈,下面是主要的属性,方法,事件,最好是参考官网API文档。
主要的属性
readySate:状态,对应三个枚举值,EMPTY,LOADING,DONE
result : 读取完毕后的内容,一般onload后调用。
error: 错误,NotFoundError,SecurityError,NotReadableError
主要方法:
readAsArrayBuffer:
readAsText:
readAsDataUrl:
主要事件:
onloadstart:准备就绪,开始读取
onprogress:在读取或者解码
onload:读取完毕
onbort:终止,例如调用abort方法
onerror:发生错误
onloadend:读操作完毕,不管是读取成功还是失败
我就不多说,今天演练的是readAsText,我想到的场景就是在线文本比较,在线JSON格式化,在线文本编辑。
来吧,少年,在线JSON格式化,50行代码做个demo。
源码路径:https://github.com/xiangwenhu/BlogCodes
html代码:
<!DOCTYPE>
<html> <head>
<title>FileReader 之 readAsText</title>
</head> <body style="margin: 2rem auto">
<div id="container" style="margin-left: 5rem">
<input type="file" id="file" onchange="handleFiles(this.files)" />
<div id="results"></div>
</div>
</body>
<script src="js/readAsText.js"></script> </html>
js代码:
function handleFiles(files) {
if (files.length) {
let file = files[0], reader = new FileReader()
reader.onload = () => {
(new JSONParser(reader.result, '#results')).init()
}
reader.readAsText(file)
}
}
class JSONParser {
constructor(source, selector) {
this.source = source
this.selector = selector
this.results = []
this.deep = 0
}
init() {
try {
let json = JSON.parse(this.source)
this.format(undefined, json)
document.querySelector(this.selector).innerHTML = this.results.join('<br/>')
} catch (e) {
alert(e)
}
}
format(key = '', value) {
if (value instanceof Array) {
this.results.push(this.generateLine(key, '['))
this.deep++
value.forEach((v, i) => {
this.format(i, v)
})
this.deep--
this.results.push(this.generateLine(undefined, ']'))
} else if (value && typeof value == 'object') {
this.results.push(this.generateLine(key, '{'))
Object.keys(value).forEach(k => {
this.deep++
this.format(k, value[k])
this.deep--
})
this.results.push(this.generateLine(undefined, '}'))
} else {
this.results.push(this.generateLine(key, value))
}
}
generateLine(key, value) {
let k = key === undefined || key === '' ? '' : `${key}:`,
v = value === null ? 'null' : value
return ' '.repeat(this.deep) + `${k}${v}`
}
}
效果:
File API文件操作之FileReader的更多相关文章
-
File API文件操作之FileReader二
上一篇说了FileAPI中FileReader的readAsText,这里继续上文,说说另外一个API readAsDataURL. 这个接口是将File或者Blob读成base64格式的字符串,然后 ...
-
JAVASE02-Unit06: 文件操作——File 、 文件操作—— RandomAccessFile
Unit06: 文件操作--File . 文件操作-- RandomAccessFile java.io.FileFile的每一个实例是用来表示文件系统中的一个文件或目录 package day06; ...
-
[转]JavaScript文件操作(2)-FileReader
在上篇文章中,我介绍了在JavaScript操作文件,重点讲了如何取得File对象. 这些对象包含的文件的元数据在上传或者拖放到浏览器中时可以获取到.有了文件当然接下来就是读取文件了. FileRea ...
-
C使用FILE指针文件操作
文件的基本概念 所谓“文件”是指一组相关数据的有序集合. 这个数据集有一个名称,叫做文件名.实际上在前面的各章中我们已经多次使用了文件,例如源程序文件.目标文件.可执行文件.库文件 (头文件)等.文件 ...
-
【File】文件操作(初识文件操作一)
一,初识文件流 看到标题就知道接下来的所有操作对象都是面对文件进行的.那么问题来了.在java中目录是不是也属于文件呢?答案是yes.既然目录也属于文件,那么对于目录跟文件的区分就显现出来了.在接下来 ...
-
win32 api 文件操作!
CreateFile打开文件要对文件进行读写等操作,首先必须获得文件句柄,通过该函数可以获得文件句柄,该函数是通向文件世界的大门. ReadFile从文件中读取字节信息.在打开文件获得了文件句柄之后, ...
-
day8.python文件操作
打开和关闭文件 open函数 用Python内置的open()函数打开一个文件,创建一个file对象,相关的方法才可以调用它进行读写. file = open(file_name [, access_ ...
-
ASP.NET 文件操作类
1.读取文件 2.写入文件 using System; using System.Collections.Generic; using System.IO; using System.Linq; us ...
-
python 文件操作(二)
一. 文件的读写 1.找到文件 文件路径:./test.py 2.打开文件 open('文件路径','模式') 模式: r, 以只读的方式打开 w, 打开一个文件只用于写入,如文件已存在,直接重 ...
随机推荐
-
java 中 Math.rint()
Math.rint() **形参是 double System.out.println(Math.rint(2.5)); 返回 2.0 System.out.println(Math.rint(2.5 ...
-
poj 2536 Gopher II (二分匹配)
Gopher II Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 6345 Accepted: 2599 Descrip ...
-
github创建repo,本地导入git项目到github
一般地,在注册好github账号之后,你需要做的事情就是在github上创建一个repo,该repo将成为你的origin(central)repo,随后你就可以将本地的项目git repo导入到这个 ...
-
[resource-]Python 网页爬虫 &; 文本处理 &; 科学计算 &; 机器学习 &; 数据挖掘兵器谱
reference: http://www.52nlp.cn/python-%e7%bd%91%e9%a1%b5%e7%88%ac%e8%99%ab-%e6%96%87%e6%9c%ac%e5%a4% ...
-
bzoj2535 2109
做过4010这题其实就水了 把图反向之后直接拓扑排序做即可,我们可以用链表来优化 每个航班的最小起飞序号就相当于在反向图中不用这个点最迟到哪 type node=record po,next:long ...
-
codeforces 438D
在大大推荐下这个标题不明的人做.而我的最后一个非常喜欢的段树,因此,愤怒出手.认为基本上相同.大值,当最大值小于取模时能够剪枝. 今后再遇到此类问题算是能攻克了 // file name: d.cpp ...
-
20155312 张竞予 Exp4 恶意代码分析
Exp4 恶意代码分析 目录 基础问题回答 (1)如果在工作中怀疑一台主机上有恶意代码,但只是猜想,所有想监控下系统一天天的到底在干些什么.请设计下你想监控的操作有哪些,用什么方法来监控. (2)如果 ...
-
docker学习-常用命令1
一.容器管理 1.1 Docker start/stop/restart/rm 命令实例:启动|停止|重启|删除 容器mydb01# docker start|stop|restart|rm mydb ...
-
Redis数据结构以及应用场景
1. Redis数据结构以及应用场景 1.1. Memcache VS Redis 1.1.1. 选Memcache理由 系统业务以KV的缓存为主,数据量.并发业务量大,memcache较为合适 me ...
-
sparkStreaming消费kafka-1.0.1方式:direct方式(存储offset到zookeeper)
版本声明: kafka:1.0.1 spark:2.1.0 注意:在使用过程中可能会出现servlet版本不兼容的问题,因此在导入maven的pom文件的时候,需要做适当的排除操作 <?xml ...