首頁 > web前端 > js教程 > 在 JavaScript 中下載 Blob 檔案時如何強制使用特定的檔案名稱?

在 JavaScript 中下載 Blob 檔案時如何強制使用特定的檔案名稱?

Susan Sarandon
發布: 2024-12-14 08:00:19
原創
303 人瀏覽過

How Can I Force a Specific Filename When Downloading a Blob File in JavaScript?

在JavaScript 中設定強制下載的Blob 檔案名稱

直接透過window.location 下載Blob 檔案時,預設檔案名稱是隨機的細繩。但是,您可能希望設定自訂檔案名稱以使其提供更多資訊。

要實現此目的,您不能只依賴 window.location 方法。相反,您需要使用以下步驟:

  1. 建立隱藏的 元素。
  2. 將其 href 屬性設為 blob 的 URL。
  3. 將其下載屬性設定為所需的檔案名稱。
  4. 觸發 上的點選。

這是一個簡化過程的範例:

const saveData = (function () {
  const a = document.createElement("a");
  document.body.appendChild(a);
  a.style = "display: none";
  return (data, fileName) => {
    const json = JSON.stringify(data);
    const blob = new Blob([json], { type: "octet/stream" });
    const url = window.URL.createObjectURL(blob);
    a.href = url;
    a.download = fileName;
    a.click();
    window.URL.revokeObjectURL(url);
  };
})();

const data = { x: 42, s: "hello, world", d: new Date() };
const fileName = "my-download.json";

saveData(data, fileName);
登入後複製

注意:

  • 舊版瀏覽器可能不支援下載屬性。
  • 某些檔案格式可能受到限制瀏覽器,導致下載失敗。考慮使用不同的檔案副檔名(例如,JSON 的 .txt)。

以上是在 JavaScript 中下載 Blob 檔案時如何強制使用特定的檔案名稱?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板