javascript HTML5文件上傳FileReader API
來源:易賢網 閱讀:802 次 日期:2016-07-08 16:01:35
溫馨提示:易賢網小編為您整理了“javascript HTML5文件上傳FileReader API”,方便廣大網友查閱!

文件上傳功能現(xiàn)在是越來越普遍,所有的社交網站,媒體網站,比如優(yōu)酷視頻,微博等,都提供了上傳圖片,上傳視頻等功能。但過去WEB程序員都很清楚,用HTML表單上傳文件是很麻煩的事情,特別是你想了解一下用戶上傳的文件的一些屬性,必須等它上傳完成后才能知道。

未知的東西上傳到服務器上,有可能產生安全問題,也有可能體積太大,超過允許,浪費空間。現(xiàn)在好了,WEB技術在進步,HTML5帶來了很多好東西。這個FileReader API就能讓你在用戶上傳之前就能獲取上傳文件的一些基本屬性。

HTML代碼

這個FileReader API 的工作原理和 File API 一樣,需要使用input[type="file"] 元素:

<-- 一個能上傳多媒體文件的表單 -->

<input type="file" id="upload-file" multiple />

<-- 顯示圖片的地方 -->

<div id="destination"></div>

在File API這篇文章里有詳細的關于能讀取到的文件的相關信息,比如地址,體積,尺寸大小,文件類型等等。

JavaScript

這個例子中我們用input表單域上傳一張圖片,當用戶在自己的電腦里選中一張圖片后,這個圖片會被顯示到頁面上:

document.getElementById('upload-file').addEventListener('change', function() {

 var file;

 var destination = document.getElementById('destination');

 destination.innerHTML = '';

 // 循環(huán)用戶多選的文件

 for(var x = 0, xlen = this.files.length; x < xlen; x++) {

 file = this.files[x];

 if(file.type.indexOf('image') != -1) { // 非常簡單的交驗

  var reader = new FileReader();

  reader.onload = function(e) {

  var img = new Image();

  img.src = e.target.result; // 顯示圖片的地方

  destination.appendChild(img);

  };

  reader.readAsDataURL(file);

 }

 }

});

這個例子里,我們使用FileReader里的readAsDataURL方法將圖片內容轉換成base64編碼的字符串,然后使用圖片的data URI方式顯示它。其它的FileReader讀取方法還有readAsText, readAsArrayBuffer和readAsBinaryString等

有了這個FileReader API,我們就可以避免用戶先將文件上傳到服務器,在瀏覽器客戶端我們就可以進行操作。這些在上傳到服務器前的預處理是很有必要的。

以上就是本文的全部內容,希望對大家的學習有所幫助。

更多信息請查看網絡編程
易賢網手機網站地址:javascript HTML5文件上傳FileReader API

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

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