flask后端+vue前端——后端怎么发文件给前端?

首先,前端axios请求的responseType要设置为blob

javascript 复制代码
const service = axios.create({
    baseURL: 'http://127.0.0.1/api',
    timeout: 5000
    });

 //向后端发送数据,后端根据这个数据data生成文件返回
 send_coordinate(data){
        return service.post('/',data,{responseType: 'blob'});
 }

然后,后端要返回文件字节流

javascript 复制代码
from flask import Flask,Response


@app.route('/', methods=['POST'])
def coordinate():
    res = request.form['data'] # 取前端数据

    # 保存为txt文件
    with open("1.txt", 'w', encoding='utf-8') as f:  
       f.write(data) 
    
    # 以字节方式读取
    with open(filename, 'rb') as f:
        bytes_data = f.read()
    
    # 用Response对象构造返回值,需要指定文件类型
    return Response(bytes_data, mimetype="text/plain")

接着,前端在axios的then中,把res.data转为Blob对象,然后创建URL,赋值给a标签的href属性

javascript 复制代码
user.send_coordinate(formData)
    .then(res=>{
                            
       let blob = new Blob([res.data], {type: 'text/plain'}); //这一步是关键
       this.downloadURL=URL.createObjectURL(blob) // 生成临时URL,赋值给变量
       this.filedownload=true // 标记变量,显示a标签(下载链接)
                           
     })

最后,a标签与vue变量如下

html 复制代码
<a v-if="filedownload" :href="downloadURL" download="coordinate.txt">下载轨迹文件</a>
javascript 复制代码
export default {
    name: 'PickTrack',
    data() {
        return {
            filedownload:false,   //是否有文件可下载
            downloadURL:''        //临时下载链接
        }
    },
相关推荐
2503_928411561 天前
11.24 Vue-组件2
前端·javascript·vue.js
Bigger1 天前
🎨 用一次就爱上的图标定制体验:CustomIcons 实战
前端·react.js·icon
谢尔登1 天前
原来Webpack在大厂中这样进行性能优化!
前端·webpack·性能优化
weixin79893765432...1 天前
Vue + Express + DeepSeek 实现一个简单的对话式 AI 应用
vue.js·人工智能·express
高级程序源1 天前
springboot社区医疗中心预约挂号平台app-计算机毕业设计源码16750
java·vue.js·spring boot·mysql·spring·maven·mybatis
cypking1 天前
Vue 3 + Vite + Router + Pinia + Element Plus + Monorepo + qiankun 构建企业级中后台前端框架
前端·javascript·vue.js
雨雨雨雨雨别下啦1 天前
【从0开始学前端】vue3简介、核心代码、生命周期
前端·vue.js·vue
simon_93491 天前
受够了压缩和收费?我作为一个码农,手撸了一款无限容量、原图直出的瀑布流相册!
前端
e***87701 天前
windows配置永久路由
android·前端·后端
Dorcas_FE1 天前
【tips】动态el-form-item中校验的注意点
前端·javascript·vue.js