html filereader 压缩,HTML5 FileReader示例

这篇博客介绍了如何使用JavaScript读取文件,特别是通过FileReader API进行部分读取以提高效率。文章强调了利用Blob的slice方法截取文件部分内容来节省读取时间,这对于处理大型文件或只需关注文件特定部分的情况尤其有用。
摘要由CSDN通过智能技术生成

这个示例并没做优化,仅作为《Javascript高级程序设计》的部分摘录

完整读取

var fileInput = document.getElementById('file');

fileInput.addEventListener('change', function(event) {

var info = "",

output = document.getElementById('output'),

progress = document.getElementById('progress'),

files = event.target.files,

type = 'default',

reader = new FileReader();

if (/image/.test(files[0].type)) {

reader.readAsDataURL(files[0]);

type = 'image';

} else {

reader.readAsText(files[0]);

type = 'text';

}

reader.onerror = function() {

output.innerHTML = "Could not read file, error code is " +

reader.error.code;

};

reader.onprogress = function(event) {

if (event.lengthComputable) {

progress.innerHTML = event.loaded + "/" + event.total;

}

};

reader.onload = function() {

var html = "";

switch(type) {

case 'image':

html = `%24%7Breader.result%7D`;

break;

case 'text':

html = reader.result;

break;

}

output.innerHTML = html;

}

});

Document

部分读取

部分读取只需要调用input.files[0].slice(begin, end)截取一部分内容即可,范围是[begin,end), 如:

reader.readAsDataURL(files[0].slice(begin, end))

为什么可以这样写呢?

下面是读取方法的函数签名:

void abort();

void readAsArrayBuffer(in Blob blob);

void readAsBinaryString(in Blob blob);

void readAsDataURL(in Blob blob);

void readAsText(in Blob blob, [optional] in DOMString encoding);

这些方法都接受一个Blob类型的对象,实际上File是Blob的子类,File的slice方法就是Blob类上的slice方法,返回值也是Blob类型对象

只读取文件的一部分可以节省时间,非常适合只关注数据中某个特定部分(如文件头部)的情况。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值