cleanm 2022-05-19 10:06 采纳率: 100%
浏览 206
已结题

使用ajax请求post,正确响应但then代码块的内容无法执行

使用ajax请求post,请求体为图片,控制台得到了响应结果,状态为200,但then代码块的内容无法执行,代码如下


 methods: {
    submitUpload() {
      if(this.img!=''){
        this.loading = true;
        let param = new FormData()  // 创建form对象
      param.append('file', this.img, this.img.name)  // 通过append向form对象添加数据
      let config = {
        headers: {'Content-Type': 'multipart/form-data'}
      }
      this.$axios.post(this.action,param, config).then(response => {
          console.log(response);
          this.result = response.data;
          this.loading = false;
          this.img='';
          
        }).catch(error=>{
          console.log(error);
          
        })
      }else{
        this.$refs.upload.submit();
      }
    },
运行结果及报错内容

console无输出,且前端不显示结果,但后台有响应

img

我的解答思路和尝试过的方法

有说ajax是异步操作,但修改代码如下还是一样的结果


let post = ()=>{
          return new Promise(resolve => {
            this.$axios.post(this.action,param, config)
            .then(response => {
          
              resolve(response);
            })
          });
        }
        this.result = await post();
        this.loading = false;
        this.img=''
        console.log(this.result);
我想要达到的结果

猜测是then没有执行,请问大家是否有解决方法

  • 写回答

3条回答 默认 最新

  • 酷爱码 2022-05-19 10:43
    关注

    不一定吧,你看看你的响应也不是json格式的呀,你是不是没有对后端的结果进行封装成json字符串呀,你后端的数据格式一般应该是
    {
    "code":200,"data":{}
    }
    这样的

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 5月27日
  • 已采纳回答 5月19日
  • 创建了问题 5月19日

悬赏问题

  • ¥15 运筹学排序问题中的在线排序
  • ¥15 关于docker部署flink集成hadoop的yarn,请教个问题 flink启动yarn-session.sh连不上hadoop,这个整了好几天一直不行,求帮忙看一下怎么解决
  • ¥30 求一段fortran代码用IVF编译运行的结果
  • ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
  • ¥15 lammps拉伸应力应变曲线分析
  • ¥15 C++ 头文件/宏冲突问题解决
  • ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛
  • ¥15 请问Lammps做复合材料拉伸模拟,应力应变曲线问题