JavaScript中文件上傳API詳解
來源:易賢網 閱讀:1210 次 日期:2016-07-08 16:02:37
溫馨提示:易賢網小編為您整理了“JavaScript中文件上傳API詳解”,方便廣大網友查閱!

對于Web程序員來說,在網頁上處理文件上傳,總是一件很麻煩的事情。在過去,我們不能夠通過拖拽上傳圖片,也沒有復雜Ajax上傳技術,很少處理多文件批量上傳。我們也無法獲取上傳過程中的信息,除非上傳完成后從服務器端獲得。有時候,等你上傳完畢后才發(fā)現上傳的文件不合適!

如今,HTML5的革命,現代瀏覽器的誕生,JavaScript的升級,這些給我們提供了使用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!

});

不幸的是,這個FileList并沒有一個叫做forEach的方法,所以我們只能使用老式的循環(huán)技巧對FileList進行循環(huán)操作:

for (var i = 0, fileCount = uploadInput.files.length; i < fileCount; i++) {

 console.log(files[i]);

}

很重要的一點,FileList里是有一個length屬性的。

獲取單個上傳文件的信息

FileList里的每個文件對象里都保存著大量的關于這個文件的信息,包括文件的體積大小,文件MIME類型,最后修改時間,文件名稱等:

{

 lastModified: 1428005315000,

 lastModifiedDate: Thu Apr 02 2015 15:08:35 GMT-0500 (CDT),

 name: "profile.pdf",

 size: 135568,

 type: "application/pdf",

 webkitRelativePath: ""

}

這些基礎信息對我們來說最大的用處就是,我們可以在上傳文件之前校驗它們。例如,你可以校驗文件的類型和體積大?。?/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

 }

}

如果用戶上傳的文件的體積太大,超過了允許范圍,或上傳的類型不對,你可以阻止用戶上傳,然后給予他們必要的提示,是什么原因不能上傳成功。

以上就是對文件上傳API做的簡單介紹,希望對大家的學習有所幫助。

更多信息請查看網絡編程
易賢網手機網站地址:JavaScript中文件上傳API詳解

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網