Єдиний спосіб, про який я знаю, - це хитрість, яку використовує FileSaver.js :
- Створіть прихований
<a>
тег.
- Встановіть його
href
атрибут для URL-адреси блобу.
- Встановіть його
download
атрибут до імені файлу.
- Натисніть на
<a>
тег.
Ось спрощений приклад ( jsfiddle ):
var saveData = (function () {
var a = document.createElement("a");
document.body.appendChild(a);
a.style = "display: none";
return function (data, fileName) {
var json = JSON.stringify(data),
blob = new Blob([json], {type: "octet/stream"}),
url = window.URL.createObjectURL(blob);
a.href = url;
a.download = fileName;
a.click();
window.URL.revokeObjectURL(url);
};
}());
var data = { x: 42, s: "hello, world", d: new Date() },
fileName = "my-download.json";
saveData(data, fileName);
Я написав цей приклад, щоб проілюструвати ідею, у виробничому коді замість цього використовуйте FileSaver.js.
Примітки
- Старі браузери не підтримують атрибут "завантажити", оскільки він є частиною HTML5.
- Деякі формати файлів браузер вважає незахищеними, а завантаження не вдається. Збереження файлів JSON з розширенням txt працює для мене.