HTML5读取文件在读取文件之前返回结果

时间:2015-05-04 18:09:06

标签: javascript html5 cordova

我正在尝试阅读文本文件并返回结果。

到目前为止,我能够读取该文件,但是当我尝试返回结果时,结果将在文件读取完成之前返回。

如何强制该功能等待结果? 我认为它与回调有关,但不知道如何实现它。

MyFile.prototype.readFile = function(fileDir, fileName) {
    var strText = "";

    window.resolveLocalFileSystemURL(fileDir, gotDir, fail);
    function gotDir(dir) {
        dir.getFile(fileName, {create: true}, gotFile, fail);
    }

    function gotFile(fileEntry) {
        fileEntry.file(gotRead, fail);
    }

    function gotRead(file) {
        var reader = new FileReader();
        reader.onerror = function(evt) {
            console.log("Reading " + file.name + " Failed");
        };
        reader.onloadstart = function(evt) {
            console.log("Read " + file.name + " Starting");
        };
        reader.onload = function(evt) {
            console.log("Read " + file.name + " Successful");
        };
        reader.onloadend = function(evt) {
            console.log("Read " + file.name + " Ending");
            endRead(evt.target.result);
        };
        reader.onprogress = function(evt) {
            console.log(evt.loaded + " of " + evt.total);
        };
        reader.readAsText(file);
    }
    function endRead(value) {
        strText = value;
    }
    //returns null value before file read finishes
    return strText;
};

1 个答案:

答案 0 :(得分:2)

FileSystem api是异步的,这意味着您必须将回调传递给readFile方法,该方法将在读取文件时被调用。它无法同步执行,see this.

您可以将签名更改为:

MyFile.prototype.readFile = function(fileDir, fileName, endRead) {

删除以下行

function endRead(value) {
    strText = value;
}
//returns null value before file read finishes
return strText;

现在,您可以将函数作为第三个参数传递给readFile方法,并使用该函数的第一个参数访问文件内容。