javascript HTML5文件上傳FileReader API
文件上傳功能現(xiàn)在是越來越普遍,所有的社交網(wǎng)站,媒體網(wǎng)站,比如優(yōu)酷視頻,微博等,都提供了上傳圖片,上傳視頻等功能。但過去WEB程序員都很清楚,用HTML表單上傳文件是很麻煩的事情,特別是你想了解一下用戶上傳的文件的一些屬性,必須等它上傳完成后才能知道。
未知的東西上傳到服務(wù)器上,有可能產(chǎn)生安全問題,也有可能體積太大,超過允許,浪費(fèi)空間?,F(xiàn)在好了,WEB技術(shù)在進(jìn)步,HTML5帶來了很多好東西。這個(gè)FileReader API就能讓你在用戶上傳之前就能獲取上傳文件的一些基本屬性。
HTML代碼
這個(gè)FileReader API 的工作原理和 File API 一樣,需要使用input[type="file"] 元素:
<-- 一個(gè)能上傳多媒體文件的表單 --> <input type="file" id="upload-file" multiple /> <-- 顯示圖片的地方 --> <div id="destination"></div>
在File API這篇文章里有詳細(xì)的關(guān)于能讀取到的文件的相關(guān)信息,比如地址,體積,尺寸大小,文件類型等等。
JavaScript
這個(gè)例子中我們用input表單域上傳一張圖片,當(dāng)用戶在自己的電腦里選中一張圖片后,這個(gè)圖片會(huì)被顯示到頁面上:
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) { // 非常簡單的交驗(yàn) var reader = new FileReader(); reader.onload = function(e) { var img = new Image(); img.src = e.target.result; // 顯示圖片的地方 destination.appendChild(img); }; reader.readAsDataURL(file); } } });
這個(gè)例子里,我們使用FileReader里的readAsDataURL方法將圖片內(nèi)容轉(zhuǎn)換成base64編碼的字符串,然后使用圖片的data URI方式顯示它。其它的FileReader讀取方法還有readAsText, readAsArrayBuffer和readAsBinaryString等
有了這個(gè)FileReader API,我們就可以避免用戶先將文件上傳到服務(wù)器,在瀏覽器客戶端我們就可以進(jìn)行操作。這些在上傳到服務(wù)器前的預(yù)處理是很有必要的。
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助。
- JS中利用FileReader實(shí)現(xiàn)上傳圖片前本地預(yù)覽功能
- JavaScript使用FileReader實(shí)現(xiàn)圖片上傳預(yù)覽效果
- JavaScript中的FileReader圖片預(yù)覽上傳功能實(shí)現(xiàn)代碼
- 原生js FileReader對(duì)象實(shí)現(xiàn)圖片上傳本地預(yù)覽效果
- JS+HTML5 FileReader實(shí)現(xiàn)文件上傳前本地預(yù)覽功能
- JavaScript html5利用FileReader實(shí)現(xiàn)上傳功能
- 基于JavaScript FileReader上傳圖片顯示本地鏈接
- javascript結(jié)合fileReader 實(shí)現(xiàn)上傳圖片
- JS實(shí)現(xiàn)上傳圖片的三種方法并實(shí)現(xiàn)預(yù)覽圖片功能
- JS中FileReader類實(shí)現(xiàn)文件上傳及時(shí)預(yù)覽功能
相關(guān)文章
js獲取或設(shè)置當(dāng)前窗口url參數(shù)的小例子
這篇文章介紹了js獲取或設(shè)置當(dāng)前窗口url參數(shù)的小例子,有需要的朋友可以參考一下2013-10-10如何用JS/HTML將時(shí)間戳轉(zhuǎn)換為“xx天前”的形式
如果我們有一份過去時(shí)間戳,如何使用JS/HTML將時(shí)間戳轉(zhuǎn)換為“xx天前”的形式呢?很多朋友都覺得解決辦法有點(diǎn)困難,其實(shí)很簡單的,下面小編給大家分享完整的實(shí)現(xiàn)代碼,一起看看吧2017-02-02PHP中如何unicode編碼,在JavaScript中h如何解碼
PHP中如何unicode編碼,在JavaScript中如何解碼?js中h這樣的,怎么轉(zhuǎn)碼?2023-07-07Bootstrap的popover(彈出框)2秒后定時(shí)消失的實(shí)現(xiàn)代碼
Bootstrap Popover(彈出框)是使用定制的 Jquery 插件創(chuàng)建的。它可以用來顯示任何元素的一些信息。這篇文章主要介紹了Bootstrap的popover(彈出框)2秒后定時(shí)消失功能,需要的朋友參考下2017-02-02javascript實(shí)現(xiàn)異形滾動(dòng)輪播
這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)異形滾動(dòng)輪播,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-11-11Javascript實(shí)現(xiàn)滾動(dòng)圖片新聞的實(shí)例代碼
這篇文章主要介紹了Javascript實(shí)現(xiàn)滾動(dòng)圖片新聞的實(shí)例代碼。需要的朋友可以過來參考下,希望對(duì)大家有所幫助2013-11-11javascript驗(yàn)證內(nèi)容為數(shù)字以及長度為10的簡單實(shí)例
下面小編就為大家?guī)硪黄猨avascript驗(yàn)證內(nèi)容為數(shù)字以及長度為10的簡單實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-08-08js實(shí)現(xiàn)ArrayList功能附實(shí)例代碼
ArrayList功能想必大家都有所了解吧,本文使用js實(shí)現(xiàn)ArrayList功能并附實(shí)例代碼,想學(xué)習(xí)的朋友可以看看2014-10-10