贝利信息

JavaScript如何实现文件下载_Blob对象如何创建?

日期:2025-12-25 00:00 / 作者:幻影之瞳
JavaScript文件下载核心是用Blob封装数据并配合标签的download属性触发强制下载,关键在于正确构造符合目标格式的Blob对象并及时释放URL资源。

JavaScript 实现文件下载,核心是用 Blob 封装数据,再通过 URL.createObjectURL() 创建临时 URL,最后用 标签触发下载。关键不在“能不能”,而在“怎么构造 Blob 才符合目标文件格式”。

Blob 对象怎么创建?

Blob 是浏览器原生对象,表示不可变的、原始二进制数据。它不等于字符串或数组,但可以由多种类型的数据构造:

常见写法示例:

// 下载纯文本
const blob = new Blob(['Hello, world!'], { type: 'text/plain' });

// 下载 JSON 字符串(注意:要先转成字符串)
const data = { name: 'Alice', score: 95 };
const blob = new Blob([JSON.stringify(data, null, 2)], { type: 'application/json' });

// 下载二进制内容(如从 fetch 获取的 ArrayBuffer)
fetch('/api/report.pdf')
  .then(res => res.arrayBuffer())
  .then(buf => {
    const blob = new Blob([buf], { type: 'application/pdf' });
    // 后续下载逻辑...
  });

如何触发真实下载(而非打开)?

仅靠 window.open(url) 或直接跳转,浏览器可能在新标签页打开文本/图片/PDF,而不是下载。必须用 标签 + download 属性:

完整下载函数示例:

function downloadBlob(blob, filename) {
  const url = URL.createObjectURL(blob);
  const a = document.createElement('a');
  a.href = url;
  a.download = filename;
  document.body.appendChild(a);
  a.click();
  document.body.removeChild(a);
  URL.revokeObjectURL(url); // 用完及时释放,避免内存泄漏
}

常见问题与注意事项

实际使用中容易踩坑的地方:

替代方案:直接下载远程文件(无需 Blob)

如果只是想下载一个已知 URL 的文件(比如 CDN 上的 PDF),不需要前端构造数据,更简单:

function downloadFromUrl(url, filename) {
  const a = document.createElement('a');
  a.href = url;
  a.download = filename;
  a.click();
}

注意:该方式受跨域限制 —— 若 url 跨域且响应头不含 Access-Control-Allow-Origin,浏览器会拒绝发起请求(此时仍需走后端代理或 Blob 中转)。