前端 - 有什么可分片读取大文件的javascript类或jquery插件
PHPz
PHPz 2017-04-11 13:14:46
[JavaScript讨论组]

现在要写一个分片压缩上传插件。例如500M的文件,可以5M、5M地分片读取,每读取一片,将其压缩以后,上传至服务器。
FileReader要在全部读取完成之后才会有result,而用file.slice分片则无法获取内容,无法压缩。那么有没有什么js类或者jquery插件可以满足我的需求呢?

04-06更新问题描述:
我之前的描述可能引发歧义。相比于封装得比较完善的上传插件,我需要的是更为基础的分片读取文件(到内存)的功能。并且要一片一片地读文件,每一片读取好以后,即时进行压缩上传,再读下一片。压缩和上传的逻辑目前不重要,重要的是怎么读。

PHPz
PHPz

学习是最好的投资!

全部回复(3)
PHP中文网

解决了。意外的,我以为不行的FileReader和file.slice相互配合就是答案。

        var blob = file.slice(0, 32);

        var reader = new FileReader();
        reader.onload = function(){
            alert('Load SUCCESS!! content: ' + reader.result);

            var fData = new FormData();
            fData.append("name",file.name);
            fData.append("size",file.size);
            fData.append("type",file.type);
            fData.append("blob",reader.result);


            $.ajax({
                url: 'upload',
                type: 'POST',
                data: fData,
                processData: false,
                contentType: false,
                cache: false,
                success: function (data) {
                    alert(data);
                },
                error: function (err){
                    alert(err);
                }
            });
        };
        reader.readAsText(blob);
天蓬老师

可以研究一下 七牛的 Javascript SDK, 实现了分片上传的,不过他也不是自己实现的,是使用的是 Plupload,那么可以研究一下 Plupload。

他实现的应该只是分片上传,压缩要自己研究下。

不过服务器端配合这个的分片上传,应该就可以简单实现断点续传了,压缩也就可以缓一缓了。

阿神

对上传插件再也没有比百度WebUploader更优秀了。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号