首頁 >web前端 >js教程 >透過Ajax方式上傳檔案使用FormData進行Ajax請求

透過Ajax方式上傳檔案使用FormData進行Ajax請求

亚连
亚连原創
2018-05-23 15:41:351502瀏覽

這篇文章主要介紹了透過Ajax方式上傳檔案使用FormData進行Ajax請求的相關資料,需要的朋友可以參考下

透過傳統的form表單提交的方式上傳檔案:

Html程式碼 

<form id= "uploadForm" action= "http://localhost:8080/cfJAX_RS/rest/file/upload" method= "post" enctype ="multipart/form-data"> 
   <h1 >测试通过Rest接口上传文件 </h1> 
   <p >指定文件名: <input type ="text" name="filename" /></p> 
   <p >上传文件: <input type ="file" name="file" /></p> 
   <p >关键字1: <input type ="text" name="keyword" /></p> 
   <p >关键字2: <input type ="text" name="keyword" /></p> 
   <p >关键字3: <input type ="text" name="keyword" /></p> 
   <input type ="submit" value="上传"/> 
</form>

不過傳統的form表單提交會導致頁面刷新,但是在有些情況下,我們不希望頁面被刷新,這種時候我們都是使用Ajax的方式進行請求的:

Js程式碼 

$.ajax({ 
   url : "http://localhost:8080/STS/rest/user", 
   type : "POST", 
   data : $( &#39;#postForm&#39;).serialize(), 
   success : function(data) { 
     $( &#39;#serverResponse&#39;).html(data); 
   }, 
   error : function(data) { 
     $( &#39;#serverResponse&#39;).html(data.status + " : " + data.statusText + " : " + data.responseText); 
   } 
});

#如上,透過$('#postForm').serialize()可以對form表單進行序列化,從而將form表單中的所有參數傳遞到服務端。

但是上述方式,只能傳遞一般的參數,上傳檔案的檔案流是無法被序列化並傳遞的。
不過如今主流瀏覽器都開始支援一個叫做FormData的對象,有了這個FormData,我們就可以輕鬆地使用Ajax方式進行檔案上傳了。

關於FormData及其用法

FormData是什麼呢?我們來看看Mozilla上的介紹。

XMLHttpRequest Level 2新增了一個新的介面FormData.利用FormData物件,我們可以透過JavaScript用一些鍵值對來模擬一系列表單控制項,我們也可以使用XMLHttpRequest的send()方法來異步的提交這個"表單".比起普通的ajax,使用FormData的最大優點就是我們可以異步上傳一個二進位檔案. 

所有主流瀏覽器的較新版本都已經支援這個物件了,例如Chrome 7 、Firefox 4 、IE 10 、Opera 12 、Safari 5 。

參見:https://developer.mozilla.org/zh-CN/docs/Web/API/XMLHttpRequest/FormData

##這裡只展示一個透過from表單來初始化FormData的方式

<form enctype="multipart/form-data" method="post" name="fileinfo">

Js程式碼 

var oData = new FormData(document.forms.namedItem("fileinfo" )); 
oData.append( "CustomField", "This is some extra data" ); 
var oReq = new XMLHttpRequest(); 
oReq.open( "POST", "stash.php" , true ); 
oReq.onload = function(oEvent) { 
   if (oReq.status == 200) { 
     oOutput.innerHTML = "Uploaded!" ; 
   } else { 
     oOutput.innerHTML = "Error " + oReq.status + " occurred uploading your file.<br \/>"; 
   } 
}; 
oReq.send(oData);

請參考:https://developer.mozilla.org/zh-CN/docs/Web/Guide/Using_FormData_Objects

#使用FormData,進行Ajax請求並上傳檔案

這裡使用JQuery,但是舊版的JQuery例如1.2是不支援的,最好使用2.0或更新版本:

#Html程式碼

<form id= "uploadForm"> 
   <p >指定文件名: <input type="text" name="filename" value= ""/></p > 
   <p >上传文件: <input type="file" name="file"/></ p> 
   <input type="button" value="上传" onclick="doUpload()" /> 
</form>

Js程式碼 

function doUpload() { 
   var formData = new FormData($( "#uploadForm" )[0]); 
   $.ajax({ 
     url: &#39;http://localhost:8080/cfJAX_RS/rest/file/upload&#39; , 
     type: &#39;POST&#39;, 
     data: formData, 
     async: false, 
     cache: false, 
     contentType: false, 
     processData: false, 
     success: function (returndata) { 
       alert(returndata); 
     }, 
     error: function (returndata) { 
       alert(returndata); 
     } 
   }); 
}

上面是我整理給大家的,希望今後對大家有幫助。

相關文章:

jQuery Ajax方式上傳檔案的方法

利用ajax實作非同步刷新請求

Ajax php實作商品分類三級連動#

以上是透過Ajax方式上傳檔案使用FormData進行Ajax請求的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn