国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

使用jquery Ajax實現上傳附件功能

2019-11-19 12:38:57
字體:
來源:轉載
供稿:網友

用過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>

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 绩溪县| 平阴县| 康马县| 寿光市| 青神县| 垫江县| 富锦市| 尖扎县| 兰西县| 九台市| 凤山县| 仲巴县| 兴仁县| 沙洋县| 梓潼县| 南通市| 济宁市| 砚山县| 刚察县| 金秀| 镇远县| 乌拉特前旗| 邻水| 德令哈市| 当阳市| 墨江| 樟树市| 双桥区| 武功县| 建水县| 平顶山市| 天镇县| 富川| 苍梧县| 武穴市| 平罗县| 崇信县| 桐庐县| 胶州市| 阜阳市| 双峰县|