在Chrome应用保存文件(Saving files in a Chrome App)

2019-10-22 18:43发布

摘要

通常情况下,我可以下载一堆文件,但是当出现下载Chrome应用不会显示下载文件架。 什么是解决这一限制Chrome应用获得的最好方法是什么?

思路

  • 我可以去通过创建一个zip文件,但这需要用户执行解压缩文件的额外步骤。
  • 我能静静地下载文件等文件下载的时候,我可以显示一个提示给用户,但这需要用户手动搜索在他们的下载文件夹中的文件。

我学到的东西

  • 无处不在互联网上告诉我使用Chrome的下载API,但这仅适用于Chrome扩展,而不是Chrome应用。
  • 我不能弹出窗口作为保存,因为50另存为窗口的50个文件是不可接受的
  • 我可以,但是,带来了使用提示chrome.fileSystem.chooseEntry({'type': "openDirectory"}要求用户选择一个目录,但我无法找到保存到该目录的方式。
  • 我的问题是基本相同的Chrome扩展程序,如何才能多文件保存到用户指定的目录? 但对于Chrome应用,而不是一个扩展。

项目和示例代码

我建立这个应用程序将是相同的这个网页我已经建立,但有一些修改,以使其作为一个web应用程序的工作。

这是我的网站,如何解决这个问题

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()

Answer 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文件系统API ,创建目录中的文件:

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


文章来源: Saving files in a Chrome App