国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

javascript HTML5文件上傳FileReader API

2019-11-20 10:18:12
字體:
來源:轉載
供稿:網友

文件上傳功能現在是越來越普遍,所有的社交網站,媒體網站,比如優酷視頻,微博等,都提供了上傳圖片,上傳視頻等功能。但過去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,我們就可以避免用戶先將文件上傳到服務器,在瀏覽器客戶端我們就可以進行操作。這些在上傳到服務器前的預處理是很有必要的。

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 湘阴县| 兴安县| 盈江县| 扶沟县| 色达县| 临泽县| 永胜县| 若尔盖县| 宁阳县| 普宁市| 灯塔市| 越西县| 原平市| 九寨沟县| 务川| 汉川市| 历史| 名山县| 邮箱| 中西区| 柳林县| 望奎县| 密山市| 呼和浩特市| 二连浩特市| 玉山县| 星子县| 东丰县| 温泉县| 历史| 淮阳县| 科技| 泰州市| 汉源县| 庆城县| 喀喇沁旗| 鹿邑县| 即墨市| 兴隆县| 玉田县| 介休市|