之前朋友說(shuō)的不刷新上傳文件。最暴力的解決方案就是上網(wǎng)上搜各種JS庫(kù),附帶多圖上傳,預(yù)覽,甚至是圖片處理等特技。那么如果不接觸第三方的庫(kù),可不可以利用ajax來(lái)做。就這個(gè)問(wèn)題,有人給出的解決方案是借助iframe,這里就不贅述了。但是Html5是個(gè)好東西,他提供了FormData,F(xiàn)ormData可以幫助我們拼湊參數(shù),乃至文件資源。這樣,我們就可以輕松用$.ajax不刷新上傳。當(dāng)然也不需要iframe。
代碼
下列是前端部分。
!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是一個(gè)表單對(duì)象,他可以將表單對(duì)象的表單域分別形成key=>value。那么是不是我們自己再拼接額外的key=>value呢,答案是可以的,詳情可以百度FormData。
還有就是為什么是$('#add')[0]?
我只能說(shuō) js = jQuery[0];
PHP部分
?php
header('Content-Type:application/json; charset=utf-8');
echo json_encode(array($_FILES,$_REQUEST));
?>
這邊只是做下測(cè)試,如果能看到$_FILES有東西,那么證明我們是可以做上傳的。
測(cè)試上傳
可以看到ajax請(qǐng)求到了ajax.php

看下preview,就可以看到返回$_FILES的相關(guān)信息了。

您可能感興趣的文章:- vuejs開(kāi)發(fā)組件分享之H5圖片上傳、壓縮及拍照旋轉(zhuǎn)的問(wèn)題處理
- H5上傳本地圖片并預(yù)覽功能
- H5手機(jī)端多文件上傳預(yù)覽插件
- 移動(dòng)端利用H5實(shí)現(xiàn)壓縮圖片上傳功能
- vue中用H5實(shí)現(xiàn)文件上傳的方法實(shí)例代碼
- H5移動(dòng)端圖片壓縮上傳開(kāi)發(fā)流程
- H5圖片壓縮與上傳實(shí)例
- H5移動(dòng)開(kāi)發(fā)Ajax上傳多張Base64格式圖片到服務(wù)器
- H5實(shí)現(xiàn)手機(jī)拍照和選擇上傳功能