javascript - ajax请求中的表单数据不完整

标签 javascript jquery ajax forms

陷入这种情况:
我使用 ajax 上传多个输入字段和图像。使用 FileReader api 将图像编码为 base64 字符串。 除了发送编码图像之外,一切似乎都正常。

我的代码(简化):

var groups = {},
    objects = {};
objects["name"] = {},
objects["group"] = {};
objects["image"] = {};

var objectCount = $(".layout-object").length;
$(".layout-object").each(function(i,v) {
   var k = objectCount-i;
   objects["name"][i] = $(v).val();
   objects["group"][i] = $("#set-object-dropdown-"+k).val();

   // get an image
   var file = document.getElementById('image-'+k).files[0];

   var reader = new FileReader();
   reader.onload = function(event) {  
      objects["image"][i] = event.target.result; // get image in base64
   };
   reader.readAsDataURL(file);
});             

$(".layout-group").each(function(i,v) {
    groups[i] = $(v).val();
});

// prepare object for ajax request...
var data = {
    name: $("#name").val(),
    groups: groups,
    objects: objects
};

// console log shows all data correctly in place = in objects there is a propery "image"...
console.log(data);

// sending ajax POST request
var posting = $.post( location.href, { data: data } );
posting.done(function(response){
        console.log(response);
});

问题:在ajax请求表单中缺少数据属性“image”,但在发布带有数据的对象之前是正确的。

也许 readAsDataURL 函数及其 onload 事件存在问题?

最佳答案

类似这样的事情:

reader.onload = function(event) {  
  objects["image"][i] = event.target.result; // get image in base64
  if (k == 1) //when the last object is iterated and it's image is set:
  {
     fireAjax();
  }

};

function fireAjax(){
    // sending ajax POST request
    var posting = $.post( location.href, { data: data } );
    posting.done(function(response){
            console.log(response);
    });
}

关于javascript - ajax请求中的表单数据不完整,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28035701/

相关文章:

javascript - 如何在Polymer 1.0中自动对焦/自动点击纸张输入?

asp.net - jQuery,ASP.NET

javascript - 如何使用 jQuery Ajax 指定正确的输入以提交多个表单(可变数字)

javascript - select2 ajax 未启动

javascript - Capybara 在 JS 完成之前进行火灾测试

javascript - 如何使用ajax和xml将自动完成搜索中的值放入隐藏字段

javascript - 如果谷歌应用程序脚本中密码输入正确,如何导航到下一页

javascript - 单击 HTML 链接调用 Javascript 函数时出错

javascript - AWS Node.js JSON 输入错误

jquery 序列化或提交表单不适用于 firefox 中的选定选项