首页  >  文章  >  web前端  >  如何在 JavaScript 中下载数据 URL:Chrome 和 Firefox 解决方案?

如何在 JavaScript 中下载数据 URL:Chrome 和 Firefox 解决方案?

Barbara Streisand
Barbara Streisand原创
2024-11-27 02:54:14655浏览

How to Download Data URLs in JavaScript: A Chrome and Firefox Solution?

在 JavaScript 中下载数据 URL

在尝试创建基于 JavaScript 的压缩/解压缩实用程序时,您遇到了以下问题下载数据 URL 中编码的文件。虽然这种方法在 Firefox 中有效,但在 Chrome 中却失败了。

Chrome 的困境

Chrome 不支持直接下载数据 URL。相反,当使用 img 标签引用时,它会将它们嵌入为图像。这会给非图像文件格式带来问题。

解决方法

幸运的是,有一个解决方法可以在 Chrome 和 Firefox 中启用数据 URL 下载。解决方案包括创建一个临时 a 元素,将其 download 属性设置为所需的文件名,并将数据 URL 分配给其 href 属性。

代码示例

以下JavaScript 函数 downloadURI 实现了这个解决方法:

function downloadURI(uri, name) {
  var link = document.createElement("a");
  link.download = name;
  link.href = uri;
  document.body.appendChild(link);
  link.click();
  document.body.removeChild(link);
  delete link;
}

用法

要使用此函数,请提供数据 URL 和所需的下载文件名作为参数:

downloadURI("data:text/html,HelloWorld!", "helloWorld.txt");

这种方法会在 Chrome 和 Firefox 中提示下载对话框,允许用户使用指定的文件名保存文件。

以上是如何在 JavaScript 中下载数据 URL:Chrome 和 Firefox 解决方案?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn