我需要将图片文件上传到画布。假设画布已经有对象,那么我必须先抓住json,上传图像,然后重新加载页面。问题是,我无法在同一个ajax请求中将上传的图像文件与json数据一起发送。这是我的代码:
<canvas id="canvas"></canvas>
<form enctype="multipart/form-data" id="myform" method="post" action="">
<input type="file" name="image" id="image" />
... (other input tags)
<button type="submit" id="upload">Upload</button>
</form>
$('#upload').bind("click",function(event) {
event.preventDefault();
var json = JSON.stringify(canvas.toDatalessObject());
var url = "upload.php";
var data = new FormData($('#myform')[0]);
var dataString = JSON.stringify(data.serializeObject());
$.post(url, { json: json, data: dataString }, 'json');
});
虽然我得到的json数据很好,但表单数据只是空的。还有其他更好的解决方案吗?
答案 0 :(得分:2)
除去
var dataString = JSON.stringify(data.serializeObject());
,已经是Json,
并尝试设置ajax属性:
processData: false,
contentType: false,