后端返回可下载的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'		// 一定一定要加上
  })
}

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

相关推荐
柒瑞8 分钟前
Superpowers结合Claude code浅实战
前端
Nian.Baikal24 分钟前
从零搭建离线地图服务:Nginx + Cesium/Leaflet 实战指南
运维·前端·nginx
前端毕业班27 分钟前
uniapp web 灵活控制 style scoped
前端·javascript·vue.js
lichenyang45331 分钟前
鸿蒙业务需求实战:AI 问题走马灯卡片实现复盘
前端
ZTStory1 小时前
mise 一款可以在项目中独立管理语言、环境变量和任务的工具
前端·rust·命令行
雁北向1 小时前
骨架屏 巴飞特 测试
前端
吴佳浩1 小时前
用 Stitch 实现 AI 前端工程化:找回消失的UI美学(别再 Vibe 瞎Coding 了)
前端·人工智能·llm
lichenyang4531 小时前
鸿蒙业务 UI 实战复盘:AI 问题走马灯卡片与 ArkTS 基础语法
前端
张元清1 小时前
在 React 里写动画又不跟渲染周期较劲:useRafFn、useRafState、useFps、useDevicePixelRatio、useUpdate
前端·javascript·面试
阿隅1 小时前
从 #xxx 私有属性到 WeakMap:彻底搞懂 JS 私有属性的前世今生与编译原理
前端