杂言
之前朋侪说的不革新上传文件。最暴力的解决方案就是上网上搜种种JS库,附带多图上传,预览,以至是图片处置惩罚等绝技。那末假如不打仗第三方的库,可不能够应用ajax来做。就这个题目,有人给出的解决方案是借助iframe,这里就不赘述了。然则Html5是个好东西,他供应了FormData,FormData能够协助我们拼集参数,以致文件资本。如许,我们就能够轻松用$.ajax不革新上传。固然也不需要iframe。
代码
以下是前端部份。
<!DOCTYLE html>
<meta charset=utf-8>
<head>
<script type="text/javascript" src="http://apps.bdimg.com/libs/jquery/2.1.1/jquery.min.js"></script>
</head>
<script type="text/javascript">
$(function(){
$('#add').submit(function(){
var data = new FormData($('#add')[0]);
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
。
另有就是为何是$('#add')[0]
?
我只能说 js = jQuery[0];
PHP部份
<?php
header('Content-Type:application/json; charset=utf-8');
echo json_encode(array($_FILES,$_REQUEST));
?>
这边只是做下测试,假如能看到$_FILES有东西,那末证实我们是能够做上传的。
测试上传
能够看到ajax要求到了ajax.php
看下preview,就能够看到返回$_FILES的相干信息了。