gpt4 book ai didi

javascript - 在 Chrome 应用程序中保存文件

转载 作者:行者123 更新时间:2023-11-30 16:55:31 29 4
gpt4 key购买 nike

总结

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

想法

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

我学到了什么

  • 互联网上到处都在告诉我使用 Chrome 的下载 API,但这只适用于 Chrome 扩展程序,而不适用于 Chrome 应用程序。
  • 我无法调出另存为窗口,因为 50 个另存为 50 个文件的窗口是 Not Acceptable
  • 不过,我可以使用 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()

最佳答案

I can, however, bring up a prompt using chrome.fileSystem.chooseEntry({'type': "openDirectory"}) to ask the user to choose a directory, but I can't find a way of saving to that directory.

这就是你需要努力的地方。

假设您声明了 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) }
    );

关于javascript - 在 Chrome 应用程序中保存文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29787301/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com