HTML5 文件域+FileReader 分段读取文件(五)
一、默认FileReader会分段读取File对象,这是分段大小不一定,并且一般会很大
HTML:
<div class="container">
<!--文本文件验证-->
<input type="file" id="file" />
<h4>选择文件如下:</h4>
<blockquote></blockquote>
</div>
JS:
//读取文本文件实例
var fileBox = document.getElementById('file');
fileBox.onchange = function () {
showFiles();
}
function showFiles() {
//获取选择文件的数组
var fileList = fileBox.files;
for (var i = 0; i < fileList.length; i++) {
var file = fileList[i];
readFile(file);
}
}
//读取文件内容
function readFile(file) {
var reader = new FileReader();
//中文windows系统 txt 文本多数默认编码 gbk
reader.readAsText(file, 'gbk');
reader.onprogress = function (e) {
//默认情况下也是分段读取,
//默认情况下,每次分段大小不确定,不同浏览器也不相同
//第一次读取比较小 Google每段:8028160(7.65625mb) FF每段:786432(768mb) IE下:4096(4k)
console.info(e);
}
reader.onload = function (e) {
var result = reader.result;
console.info(e.loaded);
}
}
二、分段读取文本文件+进度条实例,并解决IE浏览器崩溃问题
HTML:
<div class="container">
<div class="panel panel-default">
<div class="panel-heading">分段读取文件:</div>
<div class="panel-body">
<input type="file" id="file" />
<input type="button" id="abort" value="中断" />
<input type="button" id="containue" value="继续读取文件" />
<p>
<label>读取进度:</label><progress id="Progress" style="width:300px;" value="0" max="100"></progress>
</p>
<p id="Percent"></p>
<p id="Status"></p><hr />
<blockquote style="word-break:break-all;"></blockquote>
</div>
</div>
</div>
JS:
var read = {
//初始化绑定
init: function () {
var _this = this;
_this.status = document.getElementById('Status');
_this.progress = document.getElementById('Progress');
_this.percent = document.getElementById('Percent');
document.getElementById('file').onchange = _this.fileHandler;
document.getElementById('abort').onclick = _this.abortHandler;
document.getElementById('containue').onclick = _this.containueHandler;
_this.loaded = 0;
//每次读取1M
_this.step = 3 * 2;
},
//当有选中文件时,事件处理
fileHandler: function (e) {
//读取文件
var _this = read;
//获取上传文件
var file = _this.file = this.files[0];
var reader = _this.reader = new FileReader();
//绑定信息和事件
_this.total = file.size;
_this.isabort = false;//标记正在读取还是以已经中止
reader.onprogress = _this.onProgress;
reader.onabort = _this.onAbort;
reader.onerror = _this.onError;
reader.onload = _this.onLoad;
//从头读取一块
_this.readBlob(0);
$('blockquote').empty();
},
//中断 操作
abortHandler: function (e) {
var _this = read;
if (_this.reader) {
console.log('读取操作操作中止,' + _this.loaded);
_this.isabort = true;
_this.reader.abort();
}
},
//继续操作
containueHandler: function (e) {
var _this = read;
_this.isabort = false;
console.info('继续:' + _this.loaded);
//继续读取
_this.readBlob(_this.loaded);
},
//读取过程
onProgress: function (e) {
var _this = read;
if (e.lengthComputable == false)
return;
_this.loaded += e.loaded;
//更新进度条
var value = (_this.loaded / _this.total) * 100;
_this.percent.innerText = value;
_this.progress.value = value;
},
//中止上传事件
onAbort: function () {
var _this = read;
//console.log('读取操作操作中止,'+_this.loaded);
},
//当出现异常时
onError: function () { },
//读取成功 结束
onLoad: function (e) {
var _this = read;
var result = _this.reader.result;
$('blockquote').append(result);
//判断是否已经读到最后,如果没有继续读取
if (_this.loaded < _this.total) {
//IE 浏览器下,事件触发速度太快,页面容易出现假死现象,解决方案延缓事件触发
setTimeout(function () {
_this.readBlob(_this.loaded);
}, 10);
//直接使用在Google,FF没问题
// _this.readBlob(_this.loaded);
} else {
_this.loaded = _this.total;
}
},
readBlob: function (start) {
var _this = read;
if (_this.isabort)
return;
var file = _this.file;
var blob = file.slice(start, start + _this.step);
_this.reader.readAsText(blob, 'gbk');
}
};
read.init();
三、分段读取文件为ArrayBuffer+进度条显示
HTML,同上
JS:
var read = {
//初始化绑定
init: function () {
var _this = this;
_this.status = document.getElementById('Status');
_this.progress = document.getElementById('Progress');
_this.percent = document.getElementById('Percent');
document.getElementById('file').onchange = _this.fileHandler;
document.getElementById('abort').onclick = _this.abortHandler;
_this.loaded = 0;
//每次读取1M
//_this.step = 1024 * 1024;
//_this.step = 1024;
_this.step = 1024;
_this.times = 0;
},
//当有选中文件时,事件处理
fileHandler: function (e) {
//读取文件
var _this = read;
//获取上传文件
var file = _this.file = this.files[0];
var reader = _this.reader = new FileReader();
//绑定信息和事件
_this.total = file.size;
reader.onloadstart = _this.onLoadStrart;
reader.onprogress = _this.onProgress;
reader.onabort = _this.onAbort;
reader.onerror = _this.onError;
reader.onload = _this.onLoad;
//reader.onloadend = _this.onLoadEnd;
//从头读取一块
_this.readBlob(0);
$('blockquote').empty();
},
//中断
abortHandler: function (e) {
var _this = read;
if (_this.reader) {
_this.reader.abort();
}
},
//开始读取文件
onLoadStrart: function () { },
//读取过程
onProgress: function (e) {
var _this = read;
//e.loaded 当前读取的数量
//e.total 读取总量
_this.loaded += e.loaded;
//更新进度条
_this.progress.value = (_this.loaded / _this.total) * 100;
},
//中止上传事件
onAbort: function () { },
//当出现异常时
onError: function () { console.log('读取出错'); },
//读取成功 结束
onLoad: function (e) {
var _this = read;
var reader = _this.reader;
// console.info(_this.loaded + '---' + _this.total);
//console.info(reader.result); //ArrayBuffer 数组
//console.info(reader.result.byteLength); //ArrayBuffer 数组 的长度
//转换成 Int8Array 类型
//var b = new Int8Array(reader.result);
//转换成 Int32Arrary 类型
var b = new Int32Array(reader.result);
console.info(b); //ArrayBuffer 数组 的长度
$('blockquote').append(b.toString());
//判断是否已经读到最后,如果没有继续读取
if (_this.loaded < _this.total) {
_this.readBlob(_this.loaded);
} else {
_this.loaded = _this.total;
}
},
//读取结束时 ,每次读取成功结束或调用abord
onLoadEnd: function (e) {
//console.log('读取结束');
},
readBlob: function (start) {
var _this = read;
var blob,
file = _this.file;
_this.times += 1;
console.info('start:' + start);
blob = file.slice(start, start + _this.step);
_this.reader.readAsArrayBuffer(blob);
}
};
read.init();
分段读取文件(四):http://www.cnblogs.com/tianma3798/p/5839869.html
读取文件三:http://www.cnblogs.com/tianma3798/p/5839810.html
读取文件二:http://www.cnblogs.com/tianma3798/p/5839791.html
读取文件一:http://www.cnblogs.com/tianma3798/p/4355949.html
HTML5 文件域+FileReader 分段读取文件(五)的更多相关文章
- HTML5 文件域+FileReader 分段读取文件并上传(八)-WebSocket
一.同时上传多个文件处理 HTML: <div class="container"> <div class="panel panel-default&q ...
- HTML5 文件域+FileReader 分段读取文件并上传(七)-WebSocket
一.单文件上传实例 HTML: <div class="container"> <div class="panel panel-default" ...
- HTML5 文件域+FileReader 分段读取文件并上传到服务器(六)
说明:使用Ajax方式上传,文件不能过大,最好小于三四百兆,因为过多的连续Ajax请求会使后台崩溃,获取InputStream中数据会为空,尤其在Google浏览器测试过程中. 1.简单分段读取文件为 ...
- HTML5 文件域+FileReader 分段读取文件(四)
一.分段读取txt文本 HTML: <div class="container"> <div class="panel panel-default&qu ...
- html5中利用FileReader来读取文件。
利用FileReader来读取文件的能够来实现即时预览的效果,这个也是在html5中才有的功能. <!DOCTYPE html> <html lang="en"& ...
- HTML5 文件域+FileReader 读取文件(一)
在HTML5以前,HTML的文件上传域的功能具有很大的局限性,这种局限性主要体现在如下两点: 每次只能选择一个文件进行上传 客户端代码只能获取被上传文件的文件路径,无法访问实际的文件内容 一.File ...
- HTML5之fileReader异步读取文件及文件切片读取
fileReader的方法与事件 fileReade实现图片预加载 fileReade实现文件读取进度条 fileReade的与file.s实现文件切片读取 一.fileReader的方法与事件 1. ...
- Java利用内存映射文件实现按行读取文件
我们知道内存映射文件读取是各种读取方式中速度最快的,但是内存映射文件读取的API里没有提供按行读取的方法,需要自己实现.下面就是我利用内存映射文件实现按行读取文件的方法,如有错误之处请指出,或者有更好 ...
- .net上传文件,利用npoi读取文件信息到datatable里
整理代码,.net上传文件,利用npoi读取文件到datatable里,使用了FileUpload控件,代码如下: protected void Button1_Click(object sender ...
随机推荐
- 减少 WAF 漏报的 8 种方法 !
近十年来,WAF 已经逐渐发展成熟,被软件行业接受并成为无数企业保护应用的不二选择.很多大型企业甚至相继亲自设计或通过并购涉足其中,在这个硕大的市场里逐鹿竞争,同时也推动了应用层防火墙的技术演进. 与 ...
- 为什么用GPU挖比特币?
http://www.leiphone.com/gpubitcoin.html 呵呵,这么红火的东东,不了解就长不了见识. 转一下两个东东,这挖矿机天天在算什么内容,还有,当前为什么GPU比CPU有优 ...
- 【HDU3530】 [Sdoi2014]数数 (AC自动机+数位DP)
3530: [Sdoi2014]数数 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 682 Solved: 364 Description 我们称一 ...
- vsftp被动模式启用iptables访问设置
vsftpd服务搭建好之后,如果是使用主动模式访问.那么启用iptables只需添加以下规则即可: -A RH-Firewall-1-INPUT -m state --state NEW -m tcp ...
- VMware Workstation 不可恢复错误: (vcpu-0)
- mysql优化, 删除数据后物理空间未释放(转载)
mysql优化, 删除数据后物理空间未释放(转载) OPTIMIZE TABLE 当您的库中删除了大量的数据后,您可能会发现数据文件尺寸并没有减小.这是因为删除操作后在数据文件中留下碎片所致.OPTI ...
- 对于利用pca 和 cca 进行fmri激活区识别的理解
1.pca 抛开fmri研究这个范畴,我们有一个超长向量,这个超长向量在fmri研究中,就是体素数据.向量中的每个数值,都代表在相应坐标轴下的坐标值.这些坐标轴所组成的坐标系,其实是标准单位坐标系.向 ...
- 【转】windows常用消息大全(系统消息、通告消息、用户消息)
原文网址:http://blog.csdn.net/nupt123456789/article/details/7370562 附录A Windows 常用消息大全 表A-1 Windows消息分布 ...
- HDU-4972 A simple dynamic programming problem
http://acm.hdu.edu.cn/showproblem.php?pid=4972 ++和+1还是有区别的,不可大意. A simple dynamic programming proble ...
- Windows 安装Django并创建第一个应用
学习python 也有一段时间了,语法也学得差不多了,突然就想学一学python的web开源开源框架Django,我用的是Django-1.6.2.tar.gz,可以在官网https://www.dj ...