javascript - jQuery FormData 和文件

标签 javascript jquery

我正在尝试进行ajax 文件上传。当我检查变量 form_data 时它是空白的?

<form action='ajax_image_upload/process.php' method='post' enctype='multipart/form-data' class='upload_form'>
  <textarea name='description' placeholder='Type Default Video Description'></textarea>
  <span>
    Channel Image: <input type='file' name='image' />
  </span>  
  <input name='__submit__' type='submit' value='Upload'/>
</form>
var container = $(".upload_form");
var form_data = new FormData();    
form_data.append('image', container.find("form > span").children("input[name='image']"));

var post_url = container.children("form").attr("action"); //get action URL of form

//jQuery Ajax to Post form data
$.ajax({
  url : post_url,
  type: "POST",
  data: form_data,
  contentType: false,
  cache: false,
  processData: false,
  mimeType: "multipart/form-data"
}).done(function(res){ 
});

我该如何解决这个问题?

最佳答案

问题是因为您需要将文件输入中的二进制数据附加到 FormData,而不是 jQuery 对象。试试这个:

var fileData = container.find("form > span").children("input[name='image']")[0].files[0]; 
form_data.append('image', fileData);

显然,如果有多个输入或输入中有多个文件,您需要循环遍历它们并单独附加它们。

关于javascript - jQuery FormData 和文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43846370/

相关文章:

javascript - 内联 block 图像在 div 之外,就好像 float 一样

javascript - 使用 jQuery 防止在 HTML 文本框中键入空格

javascript - jQuery - 单击/取消单击时更改 Div 高度

javascript - Express JavaScript Supertest 期望特定的 json 字段

javascript - 将一行 javascript 添加到我所有域的 <head> 标记中。不确定它是什么或来自哪里

javascript - 无法通过 Canvas 上的 WebApi 调用绘制图像

javascript - 如果删除了链接,则从 html 表中删除链接之间的空格

jquery - 选择的高度在 IE 6 中很奇怪

javascript - 将数组添加到现有的嵌套数组而不重复 mongodb

javascript - 在调用 ngOnInit() 之前,Angular 构造函数不会设置局部变量