页面临时添加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
        });
    }

  

posted @ 2021-10-12 16:28  隐语者  阅读(85)  评论(0编辑  收藏  举报