1. 程式人生 > >jquery Ajax提交表單(使用jquery Ajax上傳附件)

jquery Ajax提交表單(使用jquery Ajax上傳附件)

      用過jquery的Ajax的人肯定都知道,Ajax的預設編碼方式是”application/x-www-form-urlencoded“,此編碼方式只能編碼文字型別的資料,因此Ajax傳送請求的時候,會把data序列化成 一個個String型別的鍵值對,此種傳輸資料的方式能夠滿足大部分應用場景,然而當傳輸的資料裡有附件的時候,此序列化機制便是我們的絆腳石。Ajax本身的序列化機制的硬傷歸其原因在於在html4的時代,沒有FileReader介面,在頁面裡無法讀取File(Blob)檔案,用document.getElementById("檔案控制元件的id").value只能拿到檔案的name,因此去序列化去編碼它也無從談起(個人觀點,有不同意見的歡迎給我留言)。
     眾所周知,用form提交表單的時候,有附件的時候,只要設定form的enctype="multipart/form-data",便可以上傳附件。於是博主想到,若是能用Ajax提交一個form,那上傳附件豈不是變的簡單,再也不需要使用類似AjaxFileUpload之類的外掛來作上傳。html5讓這一切便的簡單。
     FormData是html5的介面,使用它一行程式碼便可以拿到整個form表單物件:
     var form = new FormData(document.getElementById("form"));
然後我們拿著這個form物件,去賦給Ajax的data,並且阻止它將引數轉成成String型別的鍵值對,此舉需要設定processData屬性為false,此屬性預設為true;同時設定Ajax的編碼方式為false(contentType: false),在form表單裡已經設定了編碼方式,Ajax的編碼機制已經不需要,這樣我們就可以用Ajax去提交一個form物件,從而解決表單有附件的問題。需要注意的是,務必將Ajax的提交方式,設定為post,get請求只能攜帶幾kb的資料。若是不設定processData為false,去提交帶附件的form同樣是提交不上去的,它的序列化機制是硬傷。所以提交的時候,只能不使用它的序列化機制。
      一言以蔽之:借Ajax的殼,去提交form。
示例如下:

 <!DOCTYPE html>
<html>
<head>
    <script src="js/jquery-1.9.1.min.js"></script>
    <meta charset="utf-8" />
    <title>Ajax提交form</title>
    <script type="text/javascript">
    function test(){
      var form = new FormData(document.getElementById("form"));
      $.ajax({
      url:"介面地址",
      type:"post",
      data:form,
      cache: false,
      processData: false,
      contentType: false,
      success:function(data){
            alert("操作成功!");
      },
      error:function(e){
          alert("網路錯誤,請重試!!");
       }
      });        
    }
</script>
</head>
<body>
<form id="form"  enctype="multipart/form-data">
    <input type="text" id="name" name="name" />
    <input type="text" id="phone" name="phone" />
    <input type="text" id="content" name="content" />
    <input type="text" id="price" name="price" />
    <input type="text" id="ifPhone" name="ifPhone" />
    <input type="text" id="ifCerName" name="ifCerName" />
    <input type="text" id="endTime" name="endTime" />
    <input type="text" id="type" name="type" />
<input type="file" id="fileAttach" name="fileAttach" />
<input type="button" onclick="test()" value="上傳" />
</form>
</body>
</html>