后端返回可下载的xlsx文件,但是前端接收下载后为乱码

我的接收数据进行处理的代码为:

javascript 复制代码
 download_signal_list() {
   return new Promise((resolve, reject) => {
     get_download_signal({
       project_id: this.projectId,
       version_id: this.versionId
     }).then(response => {
       const url = window.URL.createObjectURL(new Blob([response.data]))
       const link = document.createElement('a')
       link.href = url
       const timestamp = this.gettimestamp(new Date().getTime() / 1000)
       const filename = timestamp + '-信号对接表.xlsx'
       link.setAttribute('download', filename)
       document.body.appendChild(link)
       link.click()
     }).catch(error => {
       reject(error)
     })
   })
 },

确实可以下载下来,但是打开后为乱码。

解决办法:

后端传的是blob类型文件,所以前端接收时也要限制一下类型,

接收的请求代码配置为:

javascript 复制代码
export function get_download_signal(data) {
  return request({
    url: baseURL + 'mf_project/signal_docking/download_signals',
    method: 'get',
    params: data,
    responseType: 'blob'		// 一定一定要加上
  })
}

之后再下载就可以正确显示啦

相关推荐
牛奶4 分钟前
开发者的"奇技淫巧":那些让你效率翻倍的实战技巧
前端·后端·程序员
咸鱼翻身更入味4 分钟前
Vue创建一个简单的Agent聊天——工具调用
前端
Timo来了4 分钟前
indexDB的用法示例
前端
walking9577 分钟前
重新学习前端之设计模式与架构
前端·javascript·面试
walking95710 分钟前
重新学习前端之TypeScript
前端·javascript·面试
walking95711 分钟前
重新学习前端之Linux
前端·vue.js·面试
walking95711 分钟前
重新学习前端之CSS
前端·vue.js·面试
walking95711 分钟前
重新学习前端之Git
前端·vue.js·面试
walking95712 分钟前
重新学习前端之小程序
前端
魔术师Grace14 分钟前
AI让我退化成原始人了
前端·程序员