溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

使用jquery Ajax實(shí)現(xiàn)上傳附件功能

發(fā)布時(shí)間:2020-10-25 04:00:24 來(lái)源:腳本之家 閱讀:202 作者:李秀才 欄目:web開(kāi)發(fā)

用過(guò)jquery的Ajax的人肯定都知道,Ajax的默認(rèn)編碼方式是”application/x-www-form-urlencoded“,此編碼方式只能編碼文本類(lèi)型的數(shù)據(jù),因此Ajax發(fā)送請(qǐng)求的時(shí)候,會(huì)把data序列化成 一個(gè)個(gè)String類(lèi)型的鍵值對(duì),此種傳輸數(shù)據(jù)的方式能夠滿足大部分應(yīng)用場(chǎng)景,然而當(dāng)傳輸?shù)臄?shù)據(jù)里有附件的時(shí)候,此序列化機(jī)制便是我們的絆腳石。Ajax本身的序列化機(jī)制的硬傷歸其原因在于在html4的時(shí)代,沒(méi)有FileReader接口,在頁(yè)面里無(wú)法讀取File(Blob)文件,用document.getElementById("文件控件的id").value只能拿到文件的name,因此去序列化去編碼它也無(wú)從談起(個(gè)人觀點(diǎn),有不同意見(jiàn)的歡迎給我留言)。

眾所周知,用form提交表單的時(shí)候,有附件的時(shí)候,只要設(shè)置form的enctype="multipart/form-data",便可以上傳附件。于是博主想到,若是能用Ajax提交一個(gè)form,那上傳附件豈不是變的簡(jiǎn)單,再也不需要使用類(lèi)似AjaxFileUpload之類(lèi)的插件來(lái)作上傳。html5讓這一切便的簡(jiǎn)單。

FormData是html5的接口,使用它一行代碼便可以拿到整個(gè)form表單對(duì)象:

     var form = new FormData(document.getElementById("form"));

然后我們拿著這個(gè)form對(duì)象,去賦給Ajax的data,并且阻止它將參數(shù)轉(zhuǎn)成成String類(lèi)型的鍵值對(duì),此舉需要設(shè)置processData屬性為false,此屬性默認(rèn)為true;同時(shí)設(shè)置Ajax的編碼方式為false(contentType: false),在form表單里已經(jīng)設(shè)置了編碼方式,Ajax的編碼機(jī)制已經(jīng)不需要,這樣我們就可以用Ajax去提交一個(gè)form對(duì)象,從而解決表單有附件的問(wèn)題。需要注意的是,務(wù)必將Ajax的提交方式,設(shè)置為post,get請(qǐng)求只能攜帶幾kb的數(shù)據(jù)。若是不設(shè)置processData為false,去提交帶附件的form同樣是提交不上去的,它的序列化機(jī)制是硬傷。所以提交的時(shí)候,只能不使用它的序列化機(jī)制。

一言以蔽之:借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("網(wǎng)絡(luò)錯(cuò)誤,請(qǐng)重試??!");
    }
   });    
  }
</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>

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI