获取 FileReader() 的结果对象

Getting the result object of FileReader()

有什么方法可以在不通过函数的情况下获取 FileReader() 的结果对象?

我在下面做了一个示例代码:

HTML

<br /> <br /> <br />

<div>

</div>

JS

var code = "lorem ipsum";

$("input[type='file']").change(function() {
    var upload = this.files[0];

    var reader = new FileReader();
    reader.onload = function() {
        code = reader.result;
        $("div").append("<label>this should appear first: " + code + "</label> <br />");
    };
    reader.readAsDataURL(upload);

    $("div").append("<label> this should appear last: " + code + "</label> <br />");
});

此代码的问题在于 reader.onload = ... 行被跳过并且 运行 紧接在脚本的最后一行之后。不是通常的从上到下阅读代码。因此,当此代码为 运行 时,您将收到如下准确结果:

this should appear last: asd 
this should appear first: ...

注意 this should appear last 先出现在 this should appear first 之前。

而如果按照脚本从上到下阅读,this should appear first必须出现在this should appear last之前。

这是我应用我的结论的地方,即 reader.onload... 行在整个过程中被跳过并且在脚本结束之前是 运行。

这是我的困境开始的地方,我需要找到一个替代代码,我不必在 reader.onload 上使用函数。简单地分配 reader.onload = reader.result 是行不通的。

使用当前代码,脚本 returns code 的第一个 运行 为 lorem ipsum,第二个 运行 returns ...。但我需要 code 在脚本第一次执行后立即成为 ...

抱歉我的解释令人困惑。我不太喜欢用英语表达自己,因为它不是我的母语。谢谢

FileReader 是异步的,因此在等待读取文件时,逻辑执行会继续经过加载事件处理程序。这意味着(与任何异步处理程序一样)所有依赖于异步事件的代码都必须放在事件处理程序中。试试这个:

var reader = new FileReader();
reader.onload = function() {
    code = reader.result;
    $("div").append("<label>this should appear first: " + code + "</label> <br />");
    $("div").append("<label> this should appear last: " + code + "</label> <br />");
};
reader.readAsDataURL(upload);

is there any way i can fetch the result object of a FileReader() without getting through a function ?

没有。 FileReader() 是异步的。您可以使用 Promise 来达到预期的结果

var code = "lorem ipsum";

    $("input[type='file']").change(function() {
      var upload = this.files[0];
      var p = new Promise(function(resolve) {
        var reader = new FileReader();
        reader.onload = function() {
          code = reader.result;
          // pass `div` as resolve `Promise` to `.then()`
          resolve($("div").append("<label>this should appear first: " 
                                  + code + "</label> <br />"));
        };
        reader.readAsDataURL(upload);
      });
      p.then(function(elem) {
        elem.append("<label> this should appear last: " 
                    + code + "</label> <br />");
      })

    });
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js">
</script>
<input type="file" />
<div></div>