即時(shí)預(yù)覽案例——H5中的FileReader

即時(shí)預(yù)覽案例中的FileReader

FileReader:讀取文件內(nèi)容

? * 1.readAsText():讀取文本文件(可以使用Txt打開的文件)尔觉,返回文本字符串,默認(rèn)編碼是UTF-8
* 2.readAsBinaryString():讀取任意類型的文件统阿。返回二進(jìn)制字符串目尖。這個(gè)方法不是用來讀取文件展示給用戶看吨瞎,而是存儲(chǔ)文件炫贤。例如:讀取文件的內(nèi)容爷恳,獲取二進(jìn)制數(shù)據(jù)方篮,傳遞給后臺(tái)名秀,后臺(tái)接收了數(shù)據(jù)之后,再將數(shù)據(jù)存儲(chǔ)
* 3.readAsDataURL():讀取文件獲取一段以data開頭的字符串藕溅,這段字符串的本質(zhì)就是DataURL.DataURL是一種將文件(這個(gè)文件一般就是指圖像或者能夠嵌入到文檔的文件格式)嵌入到文檔的方案匕得。DataURL是將資源轉(zhuǎn)換為base64編碼的字符串形式,并且將這些內(nèi)容直接存儲(chǔ)在url中>>優(yōu)化網(wǎng)站的加載速度和執(zhí)行效率。
* abort():中斷讀取

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>$$</title>
    
</head>
<body>
<!--即時(shí)預(yù)覽案例-->
<form action="">
    <input type="file" name="myFile" id="myFile" onchange="getFileContent()"><br />
    <div></div>
    <img src="" alt="" style="width:50px;height: 50px">
    <input type="submit">
</form>
<script>
    function getFileContent(){
        var reader = new FileReader();
        var file = document.querySelector("#myFile").files;//獲取圖片文件汁掠,得到的是一個(gè)數(shù)組(因?yàn)榭梢酝瑫r(shí)選擇多張圖片)(圖片文件存儲(chǔ)在input標(biāo)簽中的files屬性中)
        reader.readAsDataURL(file[0]);//調(diào)用方法轉(zhuǎn)為base64編碼的字符串形式
        reader.onload = function(){//文件讀取成功完成時(shí)觸發(fā)
            document.querySelector("img").src = reader.result;//將讀取結(jié)果賦值給img的src屬性(讀取結(jié)果存放在result中)
        }
    }
</script>
</body>
</html>

2.讀取文件略吨,獲取DataURL
* 2.1.說明沒有任何的返回值:void:但是讀取完文件之后,它會(huì)將讀取的結(jié)果存儲(chǔ)在文件讀取對(duì)象的result中
* 2.2.需要傳遞一個(gè)參數(shù) binary large object:文件(圖片或者其它可以嵌入到文檔的類型)

    * 2.3:文件存儲(chǔ)在file表單元素的files屬性中考阱,它是一個(gè)數(shù)組

獲取數(shù)據(jù)
FileReader提供一個(gè)完整的事件模型翠忠,用來捕獲讀取文件時(shí)的狀態(tài)
* onabort:讀取文件中斷片時(shí)觸發(fā)
* onerror:讀取錯(cuò)誤時(shí)觸發(fā)
* onload:文件讀取成功完成時(shí)觸發(fā)
* onloadend:讀取完成時(shí)觸發(fā),無論成功還是失敗
* onloadstart:開始讀取時(shí)觸發(fā)
* onprogress:讀取文件過程中持續(xù)觸發(fā)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末乞榨,一起剝皮案震驚了整個(gè)濱河市秽之,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌姜凄,老刑警劉巖政溃,帶你破解...
    沈念sama閱讀 211,123評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異态秧,居然都是意外死亡董虱,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,031評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門申鱼,熙熙樓的掌柜王于貴愁眉苦臉地迎上來愤诱,“玉大人,你說我怎么就攤上這事捐友∫耄” “怎么了?”我有些...
    開封第一講書人閱讀 156,723評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵匣砖,是天一觀的道長科吭。 經(jīng)常有香客問我,道長猴鲫,這世上最難降的妖魔是什么对人? 我笑而不...
    開封第一講書人閱讀 56,357評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮拂共,結(jié)果婚禮上牺弄,老公的妹妹穿的比我還像新娘。我一直安慰自己宜狐,他們只是感情好势告,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,412評(píng)論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著抚恒,像睡著了一般咱台。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上俭驮,一...
    開封第一講書人閱讀 49,760評(píng)論 1 289
  • 那天回溺,我揣著相機(jī)與錄音,去河邊找鬼。 笑死馅而,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的譬圣。 我是一名探鬼主播瓮恭,決...
    沈念sama閱讀 38,904評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼厘熟!你這毒婦竟也來了屯蹦?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,672評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤绳姨,失蹤者是張志新(化名)和其女友劉穎登澜,沒想到半個(gè)月后傀蚌,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體智末,經(jīng)...
    沈念sama閱讀 44,118評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡罩润,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,456評(píng)論 2 325
  • 正文 我和宋清朗相戀三年坷澡,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了榨惰。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片吴侦。...
    茶點(diǎn)故事閱讀 38,599評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡央星,死狀恐怖默伍,靈堂內(nèi)的尸體忽然破棺而出碾盐,到底是詐尸還是另有隱情晃跺,我是刑警寧澤,帶...
    沈念sama閱讀 34,264評(píng)論 4 328
  • 正文 年R本政府宣布毫玖,位于F島的核電站掀虎,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏付枫。R本人自食惡果不足惜烹玉,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,857評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望励背。 院中可真熱鬧春霍,春花似錦、人聲如沸叶眉。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,731評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽衅疙。三九已至莲趣,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間饱溢,已是汗流浹背喧伞。 一陣腳步聲響...
    開封第一講書人閱讀 31,956評(píng)論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人潘鲫。 一個(gè)月前我還...
    沈念sama閱讀 46,286評(píng)論 2 360
  • 正文 我出身青樓翁逞,卻偏偏與公主長得像,于是被迫代替她去往敵國和親溉仑。 傳聞我的和親對(duì)象是個(gè)殘疾皇子挖函,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,465評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • 關(guān)于Mongodb的全面總結(jié) MongoDB的內(nèi)部構(gòu)造《MongoDB The Definitive Guide》...
    中v中閱讀 31,905評(píng)論 2 89
  • ORA-00001: 違反唯一約束條件 (.) 錯(cuò)誤說明:當(dāng)在唯一索引所對(duì)應(yīng)的列上鍵入重復(fù)值時(shí),會(huì)觸發(fā)此異常浊竟。 O...
    我想起個(gè)好名字閱讀 5,249評(píng)論 0 9
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理怨喘,服務(wù)發(fā)現(xiàn),斷路器振定,智...
    卡卡羅2017閱讀 134,628評(píng)論 18 139
  • 前兩天聽好好說話必怜,邱晨講到一個(gè)非常有趣的話題,那就是人際吸引后频。的確梳庆,現(xiàn)在手機(jī)就像是我們離不開的器官,我想原因應(yīng)該不...
    宋逸斌閱讀 1,105評(píng)論 0 0
  • 日精進(jìn)打卡第62天 【知~學(xué)習(xí)】 《六項(xiàng)精進(jìn)》0遍共53遍 《大學(xué)》0遍共53遍 【經(jīng)典名句分享】 不要臉是一種生...
    土土的怪媽咪閱讀 224評(píng)論 0 0