将文件保存在Chrome应用中

时间:2015-04-22 03:40:05

标签: javascript google-chrome-app google-chrome-storage filesystem-browser

摘要

通常我可以下载一堆文件,但Chrome Apps会在下载时不显示下载文件夹。解决Chrome应用限制的最佳方法是什么?

  • 我可以通过创建一个zip文件来解决这个问题,但这需要用户执行一个解压缩文件的额外步骤。
  • 我可以静默下载文件,因此我可以在下载文件时向用户显示提示,但这需要用户在其下载文件夹中手动搜索该文件。

我学到了什么

  • 互联网上的任何地方都告诉我使用Chrome的下载API,但这仅适用于Chrome扩展程序,而不适用于Chrome应用程序。
  • 我无法启动另存为窗口,因为50个文件保存为50个文件是不可接受的
  • 但是,我可以使用chrome.fileSystem.chooseEntry({'type': "openDirectory"}提示用户选择目录,但我找不到保存到该目录的方法。
  • 我的问题与How can a Chrome extension save many files to a user-specified directory?基本相同,但适用于Chrome应用,而不是扩展程序。

项目和示例代码

我正在构建的应用程序与我构建的this webpage相同,但只需进行一些修改即可使其作为网络应用程序运行。

这就是我的网站解决问题的方法

let example_pic = ""
let a = document.createElement("a");
a.href = example_pic;

document.body.appendChild(a)
a.click();

window.URL.revokeObjectURL(a.href);
a.remove()

1 个答案:

答案 0 :(得分:1)

  

但是,我可以使用chrome.fileSystem.chooseEntry({'type': "openDirectory"})提示用户选择目录,但我找不到保存到该目录的方法。

这就是你需要做的工作。

假设您声明了fileSystem API的所有子权限:

"permissions": [
   {"fileSystem": ["write", "retainEntries", "directory"]}
]

然后你可以:

  1. 从用户处获取一个条目:

    chrome.fileSystem.chooseEntry({'type': "openDirectory"}, function(dirEntry) {
      // Check for chrome.runtime.lastError, then use dirEntry
    });
    
  2. 保留它,以便您以后可以重复使用它,而无需再次询问用户:

    dirEntryId = chrome.fileSystem.retainEntry(dirEntry);
    
    // Use chrome.storage to save/retrieve it
    
    chrome.fileSystem.restoreEntry(dirEntryId, function(entry) { /* ... */ });
    
  3. 使用HTML FileSystem API,在目录中创建文件:

    dirEntry.getFile(
      "test.txt",
      {create: true}, // add "exclusive: true" to prevent overwrite
      function(fileEntry) { /* write here */ },
      function(e) { console.error(e) }
    );