页面临时添加a元素来模拟上传下载
页面:
<input type="file" value="文件" id="btn">
JS:
window.onload = () => {
let btn = document.querySelector("input#btn");
btn.addEventListener("change", () => {
let file = btn.files[0];
let a = document.createElementNS("http://www.w3.org/1999/xhtml", 'a'); // 新建带命名空间的<a>元素
a.href = window.URL.createObjectURL(file); // 创建URL引用
a.download = "picNo1.jpg"; // 下载后的文件命名
document.body.appendChild(a); // 添加临时元素
a.click(); // 触发点击事件
document.body.removeChild(a); // 删除临时元素
window.URL.revokeObjectURL(a.href); // 删除URL引用
});
};
Eg:
模拟通过base64字符串下载文件
页面:
<input type="button" value="文件" id="btn">
JS:
btn.addEventListener("click", () => {
let picBase64 = `....`;
let a = document.createElementNS("http://www.w3.org/1999/xhtml", 'a'); // 新建带命名空间的<a>元素
a.href = window.URL.createObjectURL(base64ToBlob(picBase64)); // 创建URL引用
a.download = "picNo1.jpg"; // 下载后的文件命名
document.body.appendChild(a); // 添加临时元素
a.click(); // 触发点击事件
document.body.removeChild(a); // 删除临时元素
window.URL.revokeObjectURL(a.href); // 删除URL引用
});
function base64ToBlob(code) {
var parts = code.split(';base64,');
var contentType = parts[0].split(':')[1];
var raw = window.atob(parts[1]);
var rawLength = raw.length;
var uInt8Array = new Uint8Array(rawLength);
for (var i = 0; i < rawLength; ++i) {
uInt8Array[i] = raw.charCodeAt(i);
}
return new Blob([uInt8Array], {
type: contentType
});
}

浙公网安备 33010602011771号