文章目录

  • 一、a标签下载
  • 二、form表单下载
  • 三、window.open下载
  • 四、canvas和Image对象下载
  • 五、fetch和blob对象下载
  • 六、xhr对象和blob下载
  • 总结


        之前前端下载文件一直不是我弄的,但是最近发现一个需求要下载word文档和excel表格,之前是下载pdf和图片,之前的方法有点不适用。今天就来分享一些下载文件的方法。

一、a标签下载

这里的οnclick="return false"是取消a标签的跳转功能

<a href="下载的链接" download="下载的文件名" onclick="return false">点击下载</a>

二、form表单下载

function downloadFile(downloadUrl, fileName) {
            // 创建表单
            const formObj = document.createElement('form');
            formObj.action = `${downloadUrl}`;
            formObj.method = 'get';
            formObj.target = 'frameName'
            formObj.style.display = 'none';
            // 创建input,主要是起传参作用,这里的是为了额外传参用的
            const formItem = document.createElement('input');
            formItem.value = fileName; // 传参的值
            formItem.name = 'fileName'; // 传参的字段名
            // 插入到网页中
            document.body.appendChild(formItem);
            document.body.appendChild(formObj);
            formObj.submit(); // 发送请求
            document.body.removeChild(formObj); // 发送完清除掉
        }

三、window.open下载

window.open('下载的地址')
location.href('下载的地址')

这两种方法下载实际上和a标签一样

四、canvas和Image对象下载

function downloadImages(imgsrc) {//下载图片地址
    var image = new Image();
    // 解决跨域 Canvas 污染问题,
    image.setAttribute("crossorigin", "anonymous");
    //图片加载执行这个函数
    image.onload = function() {
    	//创建canvas
        var canvas = document.createElement("canvas");
        canvas.width = image.width;
        canvas.height = image.height;
        var context = canvas.getContext("2d");
        context.drawImage(image, 0, 0, image.width, image.height);
        var url = canvas.toDataURL("image/png"); //将图片格式转为base64
        var a = document.createElement("a"); // 生成一个a元素
        var event = new MouseEvent("click"); // 创建一个单击事件
        a.download = '图片'+ Date.now(); // 设置图片名称
        a.href = url; // 将生成的URL设置为a.href属性
        a.dispatchEvent(event); // 触发a的单击事件
    };
    image.src = imgsrc + '?time=' + Date.now();  //注意,这里是灵魂,否则依旧会产生跨域问题

}

五、fetch和blob对象下载

function downloadIamge(imgSrc) {
    let imgUrl = imgSrc;// 图片链接
    let a = document.createElement('a');
    let now =Date.now();
    // console.log(now);
    // 这里是将url转成blob地址,
    fetch(imgUrl,{
        mode:'cors'
    })  // 跨域时会报错
        .then(res => res.blob())
        .then(blob => { // 将链接地址字符内容转变成blob地址
            a.href = URL.createObjectURL(blob);
            a.download ='名字'+ now; // 下载文件的名字
            document.body.appendChild(a);
            a.click();
            //在资源下载完成后 清除 占用的缓存资源
            window.URL.revokeObjectURL(a.href);
            document.body.removeChild(a);
        })
}

六、xhr对象和blob下载

//运行时调用downfile2函数就行第一个参数是下载的地址,第二个是文件名
function downfile2(url, name2) {
            let filename2 = url;
            let fileUrl = `/down?url=${filename2}`;
            let houzhui = getExtension(filename2);
            //获取下载文件的后缀
            function getExtension(name) {
                return name.substring(name.lastIndexOf("."))
            }
            this.getBlob(fileUrl).then(blob => {
                // saveas(fig,filename) 将 fig 指定的图窗或 Simulink 模块图保存到 filename 文件中。将文件名指定为字符向量或字符串,包括文件扩展名,例如 'myplot.jpg'。文件扩展名用于定义文件格式
                this.saveAs(blob, `${name2}${houzhui}`);
            })
        }
        // 第一步,要先通过当前url 取得 blob 对象(必须)
        function getBlob(url) {
            return new Promise(resolve => {
                // axios 中的 axios.get()、axios.post()、axios() 方法,都是基于 XMLHttpRequest(简称:XHR) 封装
                const xhr = new XMLHttpRequest()
                /*  调用 open 并不会真正发送请求,而只是做好发送请求的准备工作*/
                xhr.open('GET', url, true)
                xhr.responseType = 'blob'
                // 监听 load 事件,发送完如果成功将得到的对象传给saveAs
                xhr.onload = () => {
                    if (xhr.status === 200) {
                        resolve(xhr.response)// 转为blob 请求类型类型
                    }
                }
                //调用 send() 正式发送请求
                xhr.send()
            })
        }
        function saveAs(blob, filename) {
            var link = document.createElement('a')// 创建a标签
            link.href = window.URL.createObjectURL(blob)// 获取blob 下载url
            link.download = filename//自定义文件名
            link.click();// 点击下载
        }

总结

          这些就是一些下载文件的方法,不过a标签和form表单在实践中不能下载多个文件,比如form表单下载时发送两个请求,之后发现只发送了一个请求,具体原因现在还不太确定,等研究一下在分享,或者那位大佬评论一下,大家互相学习。