欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript中文件上傳API詳解

 更新時間:2016年04月01日 15:35:03   投稿:lijiao  
這篇文章主要為大家詳細介紹了JavaScript中文件上傳API,介紹了上傳文件API的使用方法,感興趣的小伙伴們可以參考一下

對于Web程序員來說,在網頁上處理文件上傳,總是一件很麻煩的事情。在過去,我們不能夠通過拖拽上傳圖片,也沒有復雜Ajax上傳技術,很少處理多文件批量上傳。我們也無法獲取上傳過程中的信息,除非上傳完成后從服務器端獲得。有時候,等你上傳完畢后才發(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進行循環(huán)操作:

for (var i = 0, fileCount = uploadInput.files.length; i < fileCount; i++) {
 console.log(files[i]);
}

很重要的一點,F(xiàn)ileList里是有一個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做的簡單介紹,希望對大家的學習有所幫助。

相關文章

  • Express代理轉發(fā)服務器實現(xiàn)

    Express代理轉發(fā)服務器實現(xiàn)

    這篇文章主要為大家介紹了Express代理轉發(fā)服務器實現(xiàn)技巧詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-05-05
  • Layui實現(xiàn)數(shù)據表格默認全部顯示(不要分頁)

    Layui實現(xiàn)數(shù)據表格默認全部顯示(不要分頁)

    今天小編就為大家分享一篇Layui實現(xiàn)數(shù)據表格默認全部顯示(不要分頁),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • 第一次接觸神奇的Bootstrap

    第一次接觸神奇的Bootstrap

    第一次接觸神奇的Bootstrap,Bootstrap提供了用戶友好、擴瀏覽器的解決方案,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • JS實現(xiàn)無限級網頁折疊菜單(類似樹形菜單)效果代碼

    JS實現(xiàn)無限級網頁折疊菜單(類似樹形菜單)效果代碼

    這篇文章主要介紹了JS實現(xiàn)無限級網頁折疊菜單(類似樹形菜單)效果代碼,涉及JavaScript基于鼠標事件實現(xiàn)針對頁面元素結點的遍歷及樣式操作技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-09-09
  • 小程序外賣訂單界面的示例代碼

    小程序外賣訂單界面的示例代碼

    這篇文章主要介紹了小程序外賣訂單界面的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-12-12
  • javascript 面向對象技術基礎教程

    javascript 面向對象技術基礎教程

    看了很多介紹javascript面向對象技術的文章,很暈.為什么?不是因為寫得不好,而是因為太深奧.
    2009-12-12
  • javascript中數(shù)組的定義及使用實例

    javascript中數(shù)組的定義及使用實例

    這篇文章主要介紹了javascript中數(shù)組的定義及使用方法,實例分析了數(shù)組的定義及使用技巧,非常具有實用價值,需要的朋友可以參考下
    2015-01-01
  • js 圖片隨機不定向浮動的實現(xiàn)代碼

    js 圖片隨機不定向浮動的實現(xiàn)代碼

    這篇文章介紹了js圖片隨機不定向浮動的實現(xiàn)代碼,有需要的朋友可以參考一下
    2013-07-07
  • JavaScript利用發(fā)布訂閱模式編寫事件監(jiān)聽函數(shù)

    JavaScript利用發(fā)布訂閱模式編寫事件監(jiān)聽函數(shù)

    發(fā)布訂閱是一種設計模式,EventHub可以被看作是一種Pub/Sub實現(xiàn)。本文就來講講如何利用eventHub發(fā)布訂閱寫一個事件監(jiān)聽函數(shù),感興趣的可以了解一下
    2023-04-04
  • Bootstrap媒體對象的實現(xiàn)

    Bootstrap媒體對象的實現(xiàn)

    在web頁面中,圖片居左,內容居右排列,是非常常見的效果,它也就是媒體對象,它是一種抽象的樣式,可以用來構建不同類型的組件。本文給大家介紹Bootstrap媒體對象的實現(xiàn),感興趣的朋友一起學習吧
    2016-05-05

最新評論