亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > HTML5 > 正文

HTML5 FileReader對象的具體使用方法

2024-09-05 07:23:30
字體:
來源:轉載
供稿:網友

寫在前面

前一篇文章介紹了HTML5中的Blob對象(詳情戳這里),從中了解到Blob對象只是二進制數據的容器,本身并不能操作二進制,故本篇將對其操作對象FileReader進行介紹。

FileReader

FileReader主要用于將文件內容讀入內存,通過一系列異步接口,可以在主線程中訪問本地文件。

使用FileReader對象,web應用程序可以異步的讀取存儲在用戶計算機上的文件(或者原始數據緩沖)內容,可以使用File對象或者Blob對象來指定所要處理的文件或數據。

創建實例

var reader = new FileReader();

方法

方法定義 描述
abort():void 終止文件讀取操作
readAsArrayBuffer(file):void 異步按字節讀取文件內容,結果用ArrayBuffer對象表示
readAsBinaryString(file):void 異步按字節讀取文件內容,結果為文件的二進制串
readAsDataURL(file):void 異步讀取文件內容,結果用data:url的字符串形式表示
readAsText(file,encoding):void 異步按字符讀取文件內容,結果用字符串形式表示

事件

事件名稱 描述
onabort 當讀取操作被中止時調用
onerror 當讀取操作發生錯誤時調用
onload 當讀取操作成功完成時調用
onloadend 當讀取操作完成時調用,不管是成功還是失敗
onloadstart 當讀取操作將要開始之前調用
onprogress 在讀取數據過程中周期性調用

使用方法

FileReader通過異步的方式讀取文件內容,結果均是通過事件回調獲取,下面是一個讀取本地txt文件內容的例子:

var input  = document.getElementById("file"); //input fileinput.onchange = function(){    var file = this.files[0];    if(!!file){        //讀取本地文件,以gbk編碼方式輸出        var reader = new FileReader();        reader.readAsText(file,"gbk");        reader.onload = function(){            //讀取完畢后輸出結果            console.log(this.result);        }    }}

此外我們還可以通過注冊onprogress、onerror等事件,記錄文件讀取進度或異常行為等等。

讀取方式

FileReader提供了四種不同的讀取文件的方式,如:readAsArrayBuffer會將文件內容讀取為ArrayBuffer對象,readAsBinaryString則將文件讀取為二進制串,下面對這四種方式進行簡單區分。

首先準備一張圖片(6764 字節)和一個txt文本(51字節)作為測試文件:

接著編寫測試代碼:

 var reader = new FileReader();// 通過四種方式讀取文件//reader.readAsXXX(file);   reader.onload = function(){    //查看文件輸出內容    console.log(this.result);    //查看文件內容字節大小    console.log(new Blob([this.result]))}

readAsDataURL

查看圖片輸出結果:

查看txt輸出結果:

很明顯,readAsDataURL會將文件內容進行base64編碼后輸出,這個很好區分。

readAsText

此方法可以通過不同的編碼方式讀取字符,我們使用utf-8讀取

查看圖片輸出結果:

查看txt輸出結果:

readAsText讀取文件的單位是字符,故對于文本文件,只要按規定的編碼方式讀取即可;
而對于媒體文件(圖片、音頻、視頻),其內部組成并不是按字符排列,故采用readAsText讀取,會產生亂碼,同時也不是最理想的讀取文件的方式

readAsBinaryString

查看圖片輸出結果:

查看txt輸出結果:

與readAsText不同的是,readAsBinaryString函數會按字節讀取文件內容。
然而諸如0101的二進制數據只能被機器識別,若想對外可見,還是需要進行一次編碼,而readAsBinaryString的結果就是讀取二進制并編碼后的內容。
盡管readAsBinaryString方法可以按字節讀取文件,但由于讀取后的內容被編碼為字符,大小會受到影響,故不適合直接傳輸,也不推薦使用。
如:測試的圖片文件原大小為6764 字節,而通過readAsBinaryString讀取后,內容被擴充到10092個字節

readAsArrayBuffer

查看圖片輸出結果:

查看txt輸出結果:

與readAsBinaryString類似,readAsArrayBuffer方法會按字節讀取文件內容,并轉換為ArrayBuffer對象。
我們可以關注下文件讀取后大小,與原文件大小一致。
這也就是readAsArrayBuffer與readAsBinaryString方法的區別,readAsArrayBuffer讀取文件后,會在內存中創建一個ArrayBuffer對象(二進制緩沖區),將二進制數據存放在其中。通過此方式,我們可以直接在網絡中傳輸二進制內容。
好了說這么多,那ArrayBuffer到底是個毛?
關于ArrayBuffer對象牽涉的知識點比較多,完全可以單開一篇細說,在此只要簡單理解為存放了一段二進制數據的內存空間即可。
而本身ArrayBuffer中的內容對外是不可見的,若要查看其中的內容,就要引入另一個概念:類型化數組
我們可以嘗試查看下剛剛通過readAsArrayBuffer方法讀取的圖片文件內容:

可以看到,整個圖片文件的6764個字節,被分別存儲在長度為6764的數組中,而數組中每一個元素的值,為當前字節的十進制數值。
關于ArrayBuffer和類型化數組的概念在此不做深入解釋,之后會再寫一篇單獨討論。

應用場景

說了這么多,最后還是要落實到FileReader能解決什么問題,下面通過幾個例子說明:

在線預覽本地文件

我們知道,img的src屬性或background的url屬性,可以通過被賦值為圖片網絡地址或base64的方式顯示圖片。
在文件上傳中,我們一般會先將本地文件上傳到服務器,上傳成功后,由后臺返回圖片的網絡地址再在前端顯示。
通過FileReader的readAsDataURL方法,我們可以不經過后臺,直接將本地圖片顯示在頁面上。這樣做可以減少前后端頻繁的交互過程,減少服務器端無用的圖片資源,代碼如下:

var input  = document.getElementById("file");   // input fileinput.onchange = function(){    var file = this.files[0];        if(!!file){            var reader = new FileReader();            // 圖片文件轉換為base64            reader.readAsDataURL(file);            reader.onload = function(){                // 顯示圖片                document.getElementById("file_img").src = this.result;        }    }}

運行效果如下:

對于圖片上傳,我們也可以先將圖片轉換為base64進行傳輸,此時由于傳輸的圖片內容就是一段字符串,故上傳接口可以當做普通post接口處理,當圖片傳輸到后臺后,可以在轉換為文件實體存儲。
當然,考慮到base64轉換效率及其本身的大小,本方法還是適合于上傳內容簡單或所占內存較小的文件。

二進制數據上傳

HTML5體系的建立引入了一大堆新的東西,基于XHR2,我們可以直接上傳或下載二進制內容,無需像以往一樣通過form標簽由后端拉取二進制內容。
簡單整理下上傳邏輯:
1、通過input[type="file"]標簽獲取本地文件File對象
2、通過FileReader的readAsArrayBuffer方法將File對象轉換為ArrayBuffer
3、創建xhr對象,配置請求信息
4、通過xhr.sendAsBinary直接將文件的ArrayBuffer內容裝填至post body后發送
代碼實現如下:

var input  = document.getElementById("file");   // input fileinput.onchange = function(){    var file = this.files[0];        if(!!file){            var reader = new FileReader();            reader.readAsArrayBuffer(file);            reader.onload = function(){                var binary = this.result;                upload(binary);        }    }}//文件上傳function upload(binary){    var xhr = new XMLHttpRequest();    xhr.open("POST", "http://xxxx/opload");    xhr.overrideMimeType("application/octet-stream");    //直接發送二進制數據    if(xhr.sendAsBinary){        xhr.sendAsBinary(binary);    }else{        xhr.send(binary);    }        // 監聽變化    xhr.onreadystatechange = function(e){        if(xhr.readyState===4){            if(xhr.status===200){                // 響應成功                   }        }    }}

總結

本篇主要介紹了FileReader對象的屬性及應用場景,有了FileReader,我們可以將本地文件讀取到內存中。文中我們提到了ArrayBuffer和類型化數組的概念,這使得我們可以在內存中進一步操作二進制數據,關于這部分內容,會在之后的博客中進行歸納。

參考資料

[1] MDN_FileReader
[2] Unicode 和 UTF-8 有何區別

到此這篇關于HTML5 FileReader對象的具體使用方法的文章就介紹到這了,更多相關HTML5 FileReader對象內容請搜索武林網以前的文章或繼續瀏覽下面的相關文章,希望大家以后多多支持武林網!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美成人在线免费视频| 亚洲欧美日韩天堂一区二区| 国产精品大陆在线观看| 久久国产精品久久久久久| 久久久久久久久久久免费| 欧美日韩中文字幕在线| 亚洲电影免费观看高清| 国产精品午夜一区二区欲梦| 久久精品国产精品| 日韩精品一区二区三区第95| 色老头一区二区三区在线观看| 日韩欧美在线免费| 亚洲国产精品999| 日本aⅴ大伊香蕉精品视频| 九九热视频这里只有精品| 国语自产在线不卡| 亚州成人av在线| 秋霞成人午夜鲁丝一区二区三区| 亚洲福利视频专区| 97在线视频免费观看| 国产成人精品日本亚洲专区61| 大荫蒂欧美视频另类xxxx| 国产成人免费av电影| 91亚洲人电影| 久久精品视频va| 日韩成人激情在线| 2019亚洲日韩新视频| 日韩久久精品电影| 亚洲xxxx做受欧美| 日韩中文字幕精品| 欧美午夜久久久| 亚洲欧美精品suv| 成人福利视频在线观看| 欧美日韩午夜激情| 国产中文字幕亚洲| 国产极品jizzhd欧美| 亚洲精品大尺度| 欧美国产乱视频| 色妞在线综合亚洲欧美| 国产精品久久久久久久久久久新郎| 国产ts人妖一区二区三区| 国产精品91久久| 懂色av中文一区二区三区天美| 国产成人av网| 欧美激情久久久久| 国产欧亚日韩视频| 久久精品99国产精品酒店日本| 一本大道香蕉久在线播放29| 欧美激情免费看| 中日韩美女免费视频网址在线观看| 韩国精品美女www爽爽爽视频| 亚洲午夜精品久久久久久久久久久久| 97精品一区二区视频在线观看| 国产精品久久久久高潮| 日韩免费av在线| 国产日韩av高清| 欧美午夜精品久久久久久浪潮| 欧美成人精品在线| 日本久久精品视频| 欧美午夜精品伦理| 国内精品视频在线| 亚洲人成在线免费观看| 亚洲精品wwww| 国产精品视频久| 国产一区av在线| 亚洲国产成人爱av在线播放| 欧美激情一区二区三级高清视频| 在线精品91av| 国产69精品久久久久9999| 国产精品黄色影片导航在线观看| 九九久久国产精品| 韩日精品中文字幕| 国产精品视频永久免费播放| 亚洲人精选亚洲人成在线| 免费91麻豆精品国产自产在线观看| 日韩精品999| 欧美日韩一区免费| 国产精品无av码在线观看| 日韩av影片在线观看| 久久久久久噜噜噜久久久精品| 国产精品福利观看| 中文字幕精品一区二区精品| 欧美日韩在线观看视频| 亚洲国产日韩一区| 精品国产一区久久久| 欧美黑人视频一区| 精品国内自产拍在线观看| 国产欧美欧洲在线观看| 国产精品天天狠天天看| 欧美电影院免费观看| 国产精品一区二区三区久久| 成人网址在线观看| 最近2019年好看中文字幕视频| 色偷偷噜噜噜亚洲男人的天堂| 亚洲色图第一页| 黑人巨大精品欧美一区二区一视频| 精品一区二区三区电影| 国产欧美最新羞羞视频在线观看| 97精品视频在线观看| 欧美激情在线视频二区| 美日韩精品免费观看视频| 欧美另类在线播放| 91网在线免费观看| 欧美视频二区36p| 欧美精品videos| 日韩国产在线播放| 久久久999成人| 欧洲美女7788成人免费视频| 992tv在线成人免费观看| 国产亚洲精品激情久久| 国产精品美女免费视频| 亚洲一区二区三区在线免费观看| 欧美激情手机在线视频| 中文一区二区视频| 欧美亚洲免费电影| 成人信息集中地欧美| 欧美激情在线观看| 久久精品最新地址| 亚洲一区二区中文字幕| 欧美电影免费观看网站| 97视频免费在线观看| 黑人巨大精品欧美一区二区免费| 亚洲男女性事视频| 精品久久久久久久久久ntr影视| 久久久久中文字幕2018| 中文字幕亚洲无线码在线一区| 国产精品成人久久久久| 欧美裸体视频网站| 九九热精品视频国产| 这里只有精品视频在线| 精品久久久久久久久久久久久久| 国产色综合天天综合网| 久久久国产影院| 日韩在线观看免费| 亚洲美女在线看| 亚洲free性xxxx护士白浆| 狠狠爱在线视频一区| 久久久久久久久久久av| 深夜福利一区二区| 隔壁老王国产在线精品| 色妞久久福利网| 日韩电影大全免费观看2023年上| 国产成人精品免费久久久久| 国产日韩欧美在线视频观看| 亚州精品天堂中文字幕| 亚洲最大成人在线| 成人黄色片在线| 97精品国产97久久久久久免费| 亚洲加勒比久久88色综合| 亚洲欧美资源在线| 日韩三级影视基地| 97视频国产在线| 国模私拍视频一区| 在线日韩日本国产亚洲| 亚洲欧美日韩一区二区在线| 一区二区三区黄色| 日韩在线免费高清视频| 亚洲精品国产suv| 亚洲人成电影网站色www| 国产成人精品视频在线| 精品国产乱码久久久久久天美| 欧美成人在线网站| 欧美激情伊人电影| 精品国产一区二区三区久久狼5月|