首頁 >web前端 >js教程 >javascript HTML5檔案上傳FileReader API_javascript技巧

javascript HTML5檔案上傳FileReader API_javascript技巧

WBOY
WBOY原創
2016-05-16 15:06:572062瀏覽

文件上傳功能現在是越來越普遍,所有的社交網站,媒體網站,比如優酷視頻,微博等,都提供了上傳圖片,上傳視頻等功能。但過去WEB程式設計師都很清楚,用HTML表單上傳檔案是很麻煩的事情,特別是你想了解一下使用者上傳的檔案的一些屬性,必須等它上傳完成後才能知道。

未知的東西上傳到伺服器上,有可能產生安全問題,也有可能體積太大,超過允許,浪費空間。現在好了,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 = '';

 // 循环用户多选的文件
 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,我們就可以避免使用者先將檔案上傳到伺服器,在瀏覽器客戶端我們就可以操作。這些在上傳到伺服器前的預處理是很有必要的。

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

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn