weixin_33701617 2016-04-28 08:45 采纳率: 0%
浏览 122

Ajax文件上传Vue.js

I am trying to upload a file via Ajax using Vue.js - however, the server keeps responding saying that the file needs to be an image (It works when it isn't using ajax). The setup I have is as follows:

<input type="file" name="avatar" v-model="profileFormData.avatar">

And my data is:

profileFormData: {
            "name": '',
            "email": '',
            "avatar": '',
        },

Is there something specific I need to do for file uploads?

  • 写回答

1条回答 默认 最新

  • weixin_33714884 2016-04-28 11:33
    关注

    I seem to have found the fix for this. Firstly I had to remove the v-model from the form element (and every element within that form). Then rather than posting v-model, get the data to send using FormData.

    Here is an example:

    //Pass the form into a new FormData object
    var formData = new FormData(this.el);
    
    //Pass through the object instead of data passed via a v-model
        this.vm
            .$http[this.getRequestType()](this.el.action, formData)
            .then(this.onComplete.bind(this))
            .catch(this.onError.bind(this));
    
    评论

报告相同问题?

悬赏问题

  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)