JavaScript中文件上傳API詳解
對于Web程序員來說,在網(wǎng)頁上處理文件上傳,總是一件很麻煩的事情。在過去,我們不能夠通過拖拽上傳圖片,也沒有復(fù)雜Ajax上傳技術(shù),很少處理多文件批量上傳。我們也無法獲取上傳過程中的信息,除非上傳完成后從服務(wù)器端獲得。有時候,等你上傳完畢后才發(fā)現(xiàn)上傳的文件不合適!
如今,HTML5的革命,現(xiàn)代瀏覽器的誕生,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進(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里是有一個length屬性的。
獲取單個上傳文件的信息
FileList里的每個文件對象里都保存著大量的關(guān)于這個文件的信息,包括文件的體積大小,文件MIME類型,最后修改時間,文件名稱等:
{ lastModified: 1428005315000, lastModifiedDate: Thu Apr 02 2015 15:08:35 GMT-0500 (CDT), name: "profile.pdf", size: 135568, type: "application/pdf", webkitRelativePath: "" }
這些基礎(chǔ)信息對我們來說最大的用處就是,我們可以在上傳文件之前校驗(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 } }
如果用戶上傳的文件的體積太大,超過了允許范圍,或上傳的類型不對,你可以阻止用戶上傳,然后給予他們必要的提示,是什么原因不能上傳成功。
以上就是對文件上傳API做的簡單介紹,希望對大家的學(xué)習(xí)有所幫助。
- 使用ajaxfileupload.js實(shí)現(xiàn)上傳文件功能
- JS中使用FormData上傳文件、圖片的方法
- js獲取上傳文件的絕對路徑實(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移動端輕松實(shí)現(xiàn)文件上傳
- js實(shí)現(xiàn)分割上傳大文件
- js 上傳文件預(yù)覽的簡單實(shí)例
相關(guān)文章
Express代理轉(zhuǎn)發(fā)服務(wù)器實(shí)現(xiàn)
這篇文章主要為大家介紹了Express代理轉(zhuǎn)發(fā)服務(wù)器實(shí)現(xiàn)技巧詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05Layui實(shí)現(xiàn)數(shù)據(jù)表格默認(rèn)全部顯示(不要分頁)
今天小編就為大家分享一篇Layui實(shí)現(xiàn)數(shù)據(jù)表格默認(rèn)全部顯示(不要分頁),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10JS實(shí)現(xiàn)無限級網(wǎng)頁折疊菜單(類似樹形菜單)效果代碼
這篇文章主要介紹了JS實(shí)現(xiàn)無限級網(wǎng)頁折疊菜單(類似樹形菜單)效果代碼,涉及JavaScript基于鼠標(biāo)事件實(shí)現(xiàn)針對頁面元素結(jié)點(diǎn)的遍歷及樣式操作技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-09-09javascript 面向?qū)ο蠹夹g(shù)基礎(chǔ)教程
看了很多介紹javascript面向?qū)ο蠹夹g(shù)的文章,很暈.為什么?不是因?yàn)閷懙貌缓?而是因?yàn)樘願W.2009-12-12javascript中數(shù)組的定義及使用實(shí)例
這篇文章主要介紹了javascript中數(shù)組的定義及使用方法,實(shí)例分析了數(shù)組的定義及使用技巧,非常具有實(shí)用價值,需要的朋友可以參考下2015-01-01js 圖片隨機(jī)不定向浮動的實(shí)現(xiàn)代碼
這篇文章介紹了js圖片隨機(jī)不定向浮動的實(shí)現(xiàn)代碼,有需要的朋友可以參考一下2013-07-07JavaScript利用發(fā)布訂閱模式編寫事件監(jiān)聽函數(shù)
發(fā)布訂閱是一種設(shè)計(jì)模式,EventHub可以被看作是一種Pub/Sub實(shí)現(xiàn)。本文就來講講如何利用eventHub發(fā)布訂閱寫一個事件監(jiān)聽函數(shù),感興趣的可以了解一下2023-04-04