首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >HTML5 FileReader如何返回结果?

HTML5 FileReader如何返回结果?
EN

Stack Overflow用户
提问于 2012-08-06 21:44:53
回答 2查看 70.1K关注 0票数 36

我使用JS FileReader。我想在文件读取操作后得到结果,并处理这些数据。FileReader是异步的,我不知道什么时候result准备好了。如何正确地完成这项工作?

代码语言:javascript
复制
$(document).ready(function(){
    $('#file_input').on('change', function(e){
        var res = readFile(this.files[0]);

        //my some manipulate with res

        $('#output_field').text(res);
    });
});

function readFile(file){
    var reader = new FileReader(),
        result = 'empty';

    reader.onload = function(e)
    {
        result = e.target.result;
    };

    reader.readAsText(file);

    //waiting until result is empty?

    return result;
}

http://jsfiddle.net/ub22m/4/

是“空”的节目。

如何等待"result“为空?另一种方式?

EN

回答 2

Stack Overflow用户

发布于 2018-04-28 05:58:54

使用Promise包装FileReader,然后使用await获得结果:

https://blog.shovonhasan.com/using-promises-with-filereader/

票数 6
EN

Stack Overflow用户

发布于 2012-08-06 22:12:59

下面是javascript:

代码语言:javascript
复制
$(document).ready(function() {
    $('#file_input').on('change', function(e) {

        function updateProgress(evt) {
            if (evt.lengthComputable) {
                // evt.loaded and evt.total are ProgressEvent properties
                var loaded = (evt.loaded / evt.total);
                if (loaded < 1) {
                    // Increase the prog bar length
                    style.width = (loaded * 200) + "px";
                }
            }
        }

        function loaded(evt) {
            // Obtain the read file data    
            var fileString = evt.target.result;
            // Handle UTF-16 file dump
            $('#output_field').text(fileString);
        }
        var res = readFile(this.files[0]);

        var reader = new FileReader();

        reader.readAsText(this.files[0], "UTF-8");

        reader.onprogress = updateProgress;
        reader.onload = loaded;


    });
});

function readFile(file) {
    var reader = new FileReader(),
        result = 'empty';

    reader.onload = function(e) {
        result = e.target.result;
    };

    reader.readAsText(file);

    return result;
}

当然,还有HTML部分:

代码语言:javascript
复制
<input type="file" id="file_input" class="foo" />
<div id="progBar" style="background-color:black;width:1px;"> </div>
<div id="output_field" class="foo"></div>

似乎适用于*.txt文件。

See this fiddle

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11829537

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档