jQuery用FormData實(shí)現(xiàn)文件上傳的方法
前言
我們引入jQuery來進(jìn)行異步上傳可以獲得更好的用戶體驗(yàn)。 一方面,在JavaScript中進(jìn)行異步操作比表單更加靈活; 另一方面,異步上傳也避免了上傳大文件時(shí)的頁面長時(shí)間卡死。
HTML
一個(gè)type=file
的<input>
就可以讓用戶來瀏覽并選擇文件, 一般會(huì)把輸入控件放到一個(gè)<form>
中,下面的一個(gè)簡單的表單:
<form> <input type="file" id="avatar" name="avatar"> <button type="button">保存</button> </form>
但為什么我只能選擇一個(gè)文件??給<input>
添加一個(gè)multiple
屬性就可以多選了!
<input type="file" id="avatar" name="avatar" multiple>
獲取文件列表
上述的<input>
將會(huì)擁有一個(gè)叫files
的DOM屬性,包含了所選的文件列表(Array)。
$('button').click(function(){ var $input = $('#avatar'); // 相當(dāng)于: $input[0].files, $input.get(0).files var files = $input.prop('files'); console.log(files); });
這個(gè)Array
中的每一項(xiàng)都是一個(gè)File
對(duì)象,它有下面幾個(gè)主要屬性:
name: 文件名,只讀字符串,不包含任何路徑信息.
size: 文件大小,單位為字節(jié),只讀的64位整數(shù).
type: MIME類型,只讀字符串,如果類型未知,則返回空字符串.
詳情可以參考:https://developer.mozilla.org/zh-CN/docs/Using_files_from_web_applications
multipart/form-data
上傳文件比較特殊,其內(nèi)容是二進(jìn)制數(shù)據(jù),而HTTP提供的是基于文本的通信協(xié)議。 這時(shí)需要采用multipart/form-data
編碼的HTTP表單。
其HTTP消息體格式如下所示:
------WebKitFormBoundaryrGKCBY7qhFd3TrwA Content-Disposition: form-data; name="title" harttle ------WebKitFormBoundaryrGKCBY7qhFd3TrwA Content-Disposition: form-data; name="avatar"; filename="harttle.png" Content-Type: image/png ... content of harttle.png ... ------WebKitFormBoundaryrGKCBY7qhFd3TrwA--
每個(gè)字段由一段boundary string來分隔,瀏覽器保證該boundary string不與內(nèi)容重復(fù), 因而multipart/form-data
能夠成功編碼二進(jìn)制數(shù)據(jù)。
jQuery上傳文件
這是XMLHttpRequest Level 2提供的FormData
對(duì)象可以幫助我們進(jìn)行二進(jìn)制文件的 multipart/form-data
編碼:
$('button').click(function(){ var files = $('#avatar').prop('files'); var data = new FormData(); data.append('avatar', files[0]); $.ajax({ url: '/api/upload', type: 'POST', data: data, cache: false, processData: false, contentType: false }); });
url
, type
, data
想必做前端的都很熟悉了,介紹其余三個(gè)參數(shù):
cache
cache
設(shè)為false
可以禁止瀏覽器對(duì)該URL(以及對(duì)應(yīng)的HTTP方法)的緩存。 jQuery通過為URL添加一個(gè)冗余參數(shù)來實(shí)現(xiàn)。
該方法只對(duì)GET和HEAD起作用,然而IE8會(huì)緩存之前的GET結(jié)果來響應(yīng)POST請(qǐng)求。 這里設(shè)置cache: false
是為了兼容IE8。
參考:http://api.jquery.com/jquery.ajax/
contentType
jQuery中content-type
默認(rèn)值為application/x-www-form-urlencoded
, 因此傳給data參數(shù)的對(duì)象會(huì)默認(rèn)被轉(zhuǎn)換為query string(見HTTP 表單編碼 enctype)。
我們不需要jQuery做這個(gè)轉(zhuǎn)換,否則會(huì)破壞掉multipart/form-data
的編碼格式。 因此設(shè)置contentType: false
來禁止jQuery的轉(zhuǎn)換操作。
processData
jQuery會(huì)將data對(duì)象轉(zhuǎn)換為字符串來發(fā)送HTTP請(qǐng)求,默認(rèn)情況下會(huì)用 application/x-www-form-urlencoded
編碼來進(jìn)行轉(zhuǎn)換。 我們?cè)O(shè)置contentType: false
后該轉(zhuǎn)換會(huì)失敗,因此設(shè)置processData: false
來禁止該轉(zhuǎn)換過程。
我們給的data就是已經(jīng)用FormData編碼好的數(shù)據(jù),不需要jQuery進(jìn)行字符串轉(zhuǎn)換。
兼容性與其他選擇
本文介紹的jQuery文件上傳方式依賴于FormData對(duì)象, 這是XMLHttpRequest Level 2接口, 需要 IE 10+, Firefox 4.0+, Chrome 7+, Safari 5+, Opera 12+
這意味著對(duì)于低版本瀏覽器只能使用直接提交文件表單的形式, 但提交大文件表單頁面會(huì)長時(shí)間不響應(yīng),如果希望在低版本瀏覽器中解決該問題, 就只能使用別的方式來實(shí)現(xiàn)了,比如很多支持多文件和上傳進(jìn)度的Flash插件。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。謝謝大家對(duì)腳本之家的支持。
- jQuery插件ajaxfileupload.js實(shí)現(xiàn)上傳文件
- JQuery插件ajaxfileupload.js異步上傳文件實(shí)例
- 一個(gè)簡單的jQuery插件ajaxfileupload.js實(shí)現(xiàn)ajax上傳文件例子
- 分享20多個(gè)很棒的jQuery 文件上傳插件或教程
- jQuery Ajax文件上傳(php)
- jquery組件WebUploader文件上傳用法詳解
- jQuery File Upload文件上傳插件使用詳解
- 原生JS和jQuery版實(shí)現(xiàn)文件上傳功能
- jquery ajax實(shí)現(xiàn)文件上傳功能實(shí)例代碼
- jquery實(shí)現(xiàn)異步文件上傳ajaxfileupload.js
相關(guān)文章
Jquery Validate 正則表達(dá)式實(shí)用驗(yàn)證代碼大全
jQuery.validate 的正則驗(yàn)證功能,包括手機(jī)號(hào)碼、電話號(hào)碼、郵政編碼、QQ號(hào)碼、IP地址、字母和數(shù)字、中文的驗(yàn)證等2013-08-08jQuery實(shí)現(xiàn)模糊搜索功能的方法分析
這篇文章主要介紹了jQuery實(shí)現(xiàn)模糊搜索功能的方法,結(jié)合實(shí)例形式總結(jié)分析了jQuery關(guān)鍵字搜索、模糊查詢、動(dòng)態(tài)刪除table數(shù)據(jù)等相關(guān)操作技巧,需要的朋友可以參考下2018-06-06jquery檢測(cè)input checked 控件是否被選中的方法
這篇文章主要介紹了jquery檢測(cè)input checked 控件是否被選中的方法,需要的朋友可以參考下2014-03-03jQuery Ajax 實(shí)現(xiàn)在html頁面實(shí)時(shí)顯示用戶登錄狀態(tài)
本文給大家分享jQuery Ajax 實(shí)現(xiàn)在html頁面實(shí)時(shí)顯示用戶登錄狀態(tài)的實(shí)現(xiàn)方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下2016-12-12jQuery將所有被選中的checkbox某個(gè)屬性值連接成字符串的方法
這篇文章主要介紹了jQuery將所有被選中的checkbox某個(gè)屬性值連接成字符串的方法,可實(shí)現(xiàn)將選中屬性值連接成字符串的功能,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-01-01jQuery驗(yàn)證Checkbox是否選中的代碼 推薦
jQuery驗(yàn)證Checkbox是否選中的代碼,需要的朋友可以參考下。建議大家看下腳本之家的相關(guān)文章。2011-09-09