vue 下载文件

需求: 一个可以下载的接口,前端做出导出功能     接口:  https://www.cnblogs.com/kaibindirver/p/15470706.html

 方法一:

axios请求参数要加上       参考: https://www.cnblogs.com/kaibindirver/p/15396789.html 

responseType: 'arraybuffer'
axios.post('/con/mindmap/download',param,{
               "Content-Type":"application/octet-stream",
               responseType: 'arraybuffer'
            }).then(resopnse=>{
    console.log(1111)
      }
    },
其他下载下来的文件格式对应不同的TYpe 见 https://blog.csdn.net/weixin_48474646/article/details/128914894
压缩包用responseType: 'blob'

 方法二:

调用时加上红色的代码
async down2(){
        let { response } = await rzCheck02(`fortime=${this.time1}&query=${this.selctaction}&totime=${this.time2}&index=2`);
        const objectUrl = window.URL.createObjectURL(new Blob([response], {type: "application/vnd.ms-excel"}));
        const a = document.createElement('a');
        a.href = objectUrl;
        a.download = '2023.xls';
        a.click();
        a.remove();
},

 

方法三:

用open可行,单交互是会再起一个标签页下载

async down(){
// window的方法可行
window.open(`/v2/tool/check?fortime=${this.time1}&query=${this.selctaction}&totime=${this.time2}&index=2&type=${this.type}&page=4000`)
},
 
 
后计:
2023-6-7
今日有个接口需要接收file xlsx的文件 
然后结合了 方法一 和 方法二 才完成
https://www.cnblogs.com/kaibindirver/p/17463066.html
posted @ 2022-01-13 14:06  凯宾斯基  阅读(329)  评论(0编辑  收藏  举报