JavaScript中文件上傳API詳解
對(duì)于Web程序員來說,在網(wǎng)頁上處理文件上傳,總是一件很麻煩的事情。在過去,我們不能夠通過拖拽上傳圖片,也沒有復(fù)雜Ajax上傳技術(shù),很少處理多文件批量上傳。我們也無法獲取上傳過程中的信息,除非上傳完成后從服務(wù)器端獲得。有時(shí)候,等你上傳完畢后才發(fā)現(xiàn)上傳的文件不合適!
如今,HTML5的革命,現(xiàn)代瀏覽器的誕生,JavaScript的升級(jí),這些給我們提供了使用Javascript和input[type=file]元素獲取上傳文件過程信息的能力。
下面就來看看這些上傳文件API是如何使用的!
訪問要上傳的文件列表信息
如果要獲得所有input[type=file]里要上傳的文件列表,你需要使用files屬性:
// Assuming <input type="file" id="upload" multiple>
var uploadInput = document.getElementById('upload');
uploadInput.addEventListener('change', function() {
console.log(uploadInput.files) // File listing!
});
不幸的是,這個(gè)FileList并沒有一個(gè)叫做forEach的方法,所以我們只能使用老式的循環(huán)技巧對(duì)FileList進(jìn)行循環(huán)操作:
for (var i = 0, fileCount = uploadInput.files.length; i < fileCount; i++) {
console.log(files[i]);
}
很重要的一點(diǎn),F(xiàn)ileList里是有一個(gè)length屬性的。
獲取單個(gè)上傳文件的信息
FileList里的每個(gè)文件對(duì)象里都保存著大量的關(guān)于這個(gè)文件的信息,包括文件的體積大小,文件MIME類型,最后修改時(shí)間,文件名稱等:
{
lastModified: 1428005315000,
lastModifiedDate: Thu Apr 02 2015 15:08:35 GMT-0500 (CDT),
name: "profile.pdf",
size: 135568,
type: "application/pdf",
webkitRelativePath: ""
}
這些基礎(chǔ)信息對(duì)我們來說最大的用處就是,我們可以在上傳文件之前校驗(yàn)它們。例如,你可以校驗(yàn)文件的類型和體積大?。?/p>
var maxAllowedSize = 500000;
for (var i = 0, fileCount = uploadInput.files.length, totalSize = 0; i < fileCount; i++) {
totalSize += files[i].size;
if(totalSize > maxAllowedSize) {
// Notify the user that their file(s) are too large
}
if(files[i].type != 'application/pdf') {
// Notify of invalid file type for file in question
}
}
如果用戶上傳的文件的體積太大,超過了允許范圍,或上傳的類型不對(duì),你可以阻止用戶上傳,然后給予他們必要的提示,是什么原因不能上傳成功。
以上就是對(duì)文件上傳API做的簡單介紹,希望對(duì)大家的學(xué)習(xí)有所幫助。
- 使用ajaxfileupload.js實(shí)現(xiàn)上傳文件功能
- JS中使用FormData上傳文件、圖片的方法
- js獲取上傳文件的絕對(duì)路徑實(shí)現(xiàn)方法
- 原生JS封裝ajax 傳json,str,excel文件上傳提交表單(推薦)
- jQuery插件ajaxfileupload.js實(shí)現(xiàn)上傳文件
- 原生JS和jQuery版實(shí)現(xiàn)文件上傳功能
- javascript HTML5文件上傳FileReader API
- javascript html5移動(dòng)端輕松實(shí)現(xiàn)文件上傳
- js實(shí)現(xiàn)分割上傳大文件
- js 上傳文件預(yù)覽的簡單實(shí)例
相關(guān)文章
iframe與主框架跨域相互訪問實(shí)現(xiàn)方法
今天正好需要用到iframe 與主框架相互訪問的實(shí)現(xiàn)方法,正好看到了這篇文章,確實(shí)不錯(cuò),特分享一下,需要的朋友可以參考下2017-09-09
詳解使用fetch發(fā)送post請(qǐng)求時(shí)的參數(shù)處理
這篇文章主要介紹了詳解使用fetch發(fā)送post請(qǐng)求時(shí)的參數(shù)處理的相關(guān)資料,需要的朋友可以參考下2017-04-04
document.getElementById方法在Firefox與IE中的區(qū)別
相信很多朋友在寫JavaScript的時(shí)候,對(duì)瀏覽器的兼容問題會(huì)感到很頭疼。這不,煩什么,什么就來了,特記錄下來,與大家分享。2010-05-05
理解 JavaScript Scoping & Hoisting(二)
這篇文章主要介紹了理解 JavaScript Scoping & Hoisting,盡管對(duì)于有經(jīng)驗(yàn)的程序員來說這只是小菜一碟,不過我還是順著初學(xué)者常見的思路做一番描述2015-11-11
Javascript正則表達(dá)式實(shí)現(xiàn)輸入框驗(yàn)證信息功能實(shí)例
正則表達(dá)式是用于匹配字符串中字符組合的模式,在JavaScript中正則表達(dá)式也是對(duì)象,這篇文章主要給大家介紹了關(guān)于Javascript正則表達(dá)式實(shí)現(xiàn)輸入框驗(yàn)證信息功能的相關(guān)資料,需要的朋友可以參考下2024-05-05

