Google Chrome中的“文件API:目录和系统”问题

时间:2011-01-17 04:06:17

标签: javascript html5 google-chrome html5-filesystem

在Google Chrome中使用HTML5文件系统API阅读this article后,我决定将其整合到打包的网络应用程序中。

使用笔记和提供的代码作为指导,我整理了一个相当冗长的脚本,如下所示:

var FSA = FSA || {};
var fsys, root, fileReader, dropReader, dropContainer, btn = [];
window.addEventListener("load", function () {
    window.requestFileSystem(PERSISTENT, 5242880 /* ~5MB */, function(fs) {
        fsys = fs;
        root = fsys.root;
    }, FSA.error);
});
function createFile(path) { 
    root.getFile(path, {create:true, exclusive:true}, function() {
        console.log(path+ " file created"); 
    }, FSA.error); 
};
function saveFile(name, data, mimetype) {
    var e = this || null;
    name = name || e.target.name;
    data = data || e.target.result;
    mimetype = mimetype || e.target.type;
    root.getFile(name, {create: true}, function(fileEntry) {
        fileEntry.createWriter(function(writer) {
            writer.onwrite = function(e) {
                console.log(name + ' written successfully to filesystem.');
                FSA.getFile(name);
            };
            writer.onerror = function(e) {
                console.log('Write failed: ' + e);
            };
            var bb = new BlobBuilder();
            bb.append(data);
            writer.write(bb.getBlob(mimetype));
        });
    }, FSA.error);
};
function openFile(file, fileTarget) {
    root.getFile(file.name, null, function(entry) {
        entry.file(function(file) {
                reader = new FileReader();
                reader.filename = file.name;
                reader.onload = function(e) {
                    fileTarget = e.target.result;
                };
                reader.readAsText(file);
        }, FSA.error);
    }, FSA.error);
};

而且,在某种程度上,它似乎有效。我可以使用createFile函数创建一个文件,我可以使用saveFile函数来保存文件。但是,我似乎无法使用openFile函数,并且所有这三个函数都在JavaScript控制台中返回以下错误:

Uncaught TypeError: Cannot call method 'getFile' of undefined

我认为问题与变量root有关,但我可能错了。

由于这是一个新的API,以及一个草案规范,因此很少有文档可以帮助解决这个问题。

是否有人能够指出问题,如果是,请提供解决方案?

感谢您的帮助。

编辑:我正在使用“10.0.639.0 canary build”,因此我认为我的浏览器应该允许在扩展程序中使用API​​。

1 个答案:

答案 0 :(得分:2)

目前,FileSystem API getFile在任何Chrome 8上都不能在扩展程序中运行。如果要使用getFile创建新文件,则需要运行以在外部托管的网页中运行代码。 / p>

扩展程序中的Chrome 9+将支持此功能。有关更多信息,请阅读HTML5 Chromium mailing list post

我正在运行Google Chrome 10.0.634.0 Dev Channel。在检查员内:

window.requestFileSystem(PERSISTENT, 5242880 /* ~5MB */, function(fs) {
  root = fs.root;
})
root.getFile

返回:

function getFile() { [native code] }