使用JavaScript强制下载

长期以来,强制下载脚本一直是Internet可用性的重要组成部分。可以通过在服务器端实现此功能的次数。随着网络世界在客户端方面的发展,我开始寻找一种无需服务器即可强制下载的方法,然后在Firefox DevTools Debugger中找到了它。

JavaScript

执行此操作的函数非常小,并且依赖于URL.createObjectUrl :

<script type="text/javascript">
	function downloadFile(data, fileName, type="text/plain") {
  // Create an invisible A element
  const a = document.createElement("a");
  a.style.display = "none";
  document.body.appendChild(a);
  // Set the HREF to a Blob representation of the data to be downloaded
  a.href = window.URL.createObjectURL(
    new Blob([data], { type })
  );
  // Use download attribute to set set desired file name
  a.setAttribute("download", fileName); 
  // Trigger the download by simulating click
  a.click();
  // Cleanup
  window.URL.revokeObjectURL(a.href);
  document.body.removeChild(a);
}
</script>

该函数将HTML<a>元素注入到正文中,将其URL设置为目标文件的文本内容的Blob 值,然后单击该元素以触发下载。该元素在此过程中保持隐藏状态,并在click() 调用后立即从DOM中删除。调用该函数后,将立即显示浏览器的下载提示。