首頁 > php教程 > PHP开发 > 使用 jQuery.ajax 上傳帶有檔案的表單遇到的問題

使用 jQuery.ajax 上傳帶有檔案的表單遇到的問題

高洛峰
發布: 2016-12-08 13:33:41
原創
1485 人瀏覽過

今天幫人看程式碼的時候,遇到一點小問題。使用 jQuery 上傳有檔案的表單時,會有些問題。

首先,因為使用的是 FormData,所以必須在傳入 $.ajax 的參數中配置 processData: false。

否則將會拋出 Illegal invocation 的異常,因為 jQuery 預設是會對傳入的 data 欄位的資料進行處理的。

官方文件是這麼解釋的:

使用 jQuery.ajax 上傳帶有檔案的表單遇到的問題

其次,注意請求的Content-Type 首部,預設是application/x-www-form-urlencoded; charset=UTF-8,也就是我們通常見的“a=A&b=B” 這種格式。但使用 FormData 時,就不行了。

對參數添加 contentType 字段,將其值設為 false 即可。如果 jQuery 版本小於 1.6,則手動設定為 multipart/form-data。具體說明請見文件說明:

使用 jQuery.ajax 上傳帶有檔案的表單遇到的問題

我以前通常都是使用原生的 XMLHttpRequest,所以倒也沒有遇到這種問題。既然遇到了,就得解決。因此記錄下來,以備日後查找。

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門推薦
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板