<!DOCTYLE html><meta charset=utf-><head><script type="text/javascript" src="http://apps.bdimg.com/libs/jquery/../jquery.min.js"></script></head><script type="text/javascript">$(function(){$("#add").submit(function(){var data = new FormData($("#add")[]); console.log(data);$.ajax({ url: "ajax.php", type: "POST", data: data, dataType: "JSON", cache: false, processData: false, contentType: false, success:function(data){ //alert(data);alert("UploadFile Success");}}); return false;});});</script><form id="add"><input type="text" name="book"></input><input type="file" name="source"></input><input type="submit"></form>不多赘述里面的代码,就讲一行代码
var data = new FormData($("#add")[0]);FormData是一个表单对象,他可以将表单对象的表单域分别形成key=>value。那么是不是我们自己再拼接额外的key=>value呢,答案是可以的,详情可以百度FormData。
<?php header("Content-Type:application/json; charset=utf-8");echo json_encode(array($_FILES,$_REQUEST));?>这边只是做下测试,如果能看到$_FILES有东西,那么证明我们是可以做上传的。
看下preview,就可以看到返回$_FILES的相关信息了。