fetch はバックエンド ストリーム ファイルの戻りを処理し、ダウンロードを直接開きます

バックエンドによって直接返されたストリーム ファイルがこれを使用する必要がある場合は、

fetch(
    '/abcd/efg/opq/down',
    {
     method:'POST',  
    headers:{
      'Content-Type':'application/x-www-form-urlencoded',  
    },
// content-Type 我这个提交方式是表单提交 , 一般是json,
      responseType: 'blob',
// responseType 必填 ,为blob 最后这样处理
      body: formData,
// 这是我的表单参数.
    },
  ).then( response => {
// 这一段可以不用配置, 如果写公用请求可以加上,返回这种格式的话把下面的放到判断里面,
// 因为返回的响应头是application/vnd.ms-excel;charset=utf-8' 这种格式的 。excel表格
    if (
      response.headers.get('Content-Type').toLowerCase() ===
      'application/vnd.ms-excel;charset=utf-8'
    ){
    }
// 文件名字如果后端没有返回给你就自己写, 这个是返回的名字 decodeURIComponent 是把浏览器的编译//的乱码改成文字
    let filename = decodeURIComponent(response.headers.get('content-disposition').split("filename=")[1])
    response.blob()
      .then(blob => {
        let bl = new Blob([blob], {
          type: "application/vnd.ms-excel;charset=utf-8",
        })
// 在这里处理一下blob ,type加上application/vnd.ms-excel;charset=utf-8" ,因为我的后端返回为的是json 所以我设置了type 。
// 下面就是创建一个a标签 然后获取一下url 打开就完事
        let a = document.createElement('a');
        let url = window.URL.createObjectURL(bl);
        let fileName = filename;
        a.href = url;
        a.download = fileName;
        a.click();
        window.URL.revokeObjectURL(url);
      })

おすすめ

転載: blog.csdn.net/it_varlue/article/details/125596414