欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS中利用FileReader實(shí)現(xiàn)上傳圖片前本地預(yù)覽功能

 更新時(shí)間:2018年03月02日 09:17:24   作者:西風(fēng)瘦碼  
FileReader 對(duì)象允許Web應(yīng)用程序異步讀取存儲(chǔ)在用戶計(jì)算機(jī)上的文件(或原始數(shù)據(jù)緩沖區(qū))的內(nèi)容,使用 File 或 Blob 對(duì)象指定要讀取的文件或數(shù)據(jù)。下面通過本文給大家介紹JS中利用FileReader實(shí)現(xiàn)上傳圖片前本地預(yù)覽功能,需要的朋友參考下

引子

      平時(shí)做圖片上傳預(yù)覽時(shí)如果沒有特殊的要求就直接先把圖片傳到后臺(tái)去,成功之后拿到URL再渲染到頁面上,這樣做在圖片比較小的時(shí)候沒什么問題,大一點(diǎn)的話就會(huì)比較慢才能看到預(yù)覽了,而且還產(chǎn)生了垃圾文件,所以比較好的是上傳之前先在本地預(yù)覽一下。

      之前做項(xiàng)找插件的時(shí)候就知道純前端可以實(shí)現(xiàn)圖片本地預(yù)覽,可今天面試的時(shí)候被問到時(shí)竟然一臉懵逼,然后竟然無意中就在電腦桌面發(fā)現(xiàn)了實(shí)現(xiàn)的demo,然后根據(jù)demo查了一下API,稍微總結(jié)下:

首先得拿到File對(duì)象

      當(dāng)用input標(biāo)簽上傳圖片時(shí)event對(duì)象中會(huì)包含file對(duì)象的一個(gè)集合

event.target.files

核心是FileReader對(duì)象

根據(jù)MDN上的說法:

FileReader 對(duì)象允許Web應(yīng)用程序異步讀取存儲(chǔ)在用戶計(jì)算機(jī)上的文件(或原始數(shù)據(jù)緩沖區(qū))的內(nèi)容,使用 File 或 Blob 對(duì)象指定要讀取的文件或數(shù)據(jù)。

首先要作為構(gòu)造函數(shù)得到一個(gè)FileReader的實(shí)例對(duì)象

var freader = new FileReader();

利用readAsDataURL()方法讀取指定的內(nèi)容

freader.readAsDataURL(file);

最后就是一個(gè)事件處理,相當(dāng)于監(jiān)控讀取進(jìn)度,我們這里是當(dāng)讀取完成時(shí)渲染圖片,所以用onload

freader.onload = function(e) { console.log(e); myImg.setAttribute('src', e.target.result); }

這里架加載完成之后最終得到的是一個(gè)base64編碼的src地址,具體為什么下次查清楚了再專門寫篇關(guān)于base64編碼的文章

完整代碼

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Document</title>
</head>
<body>
 <form action=""> 
 <input type="file" name="files" id="fileTog" accept="image/*" multiple="multiple" onchange="changImg(event)"> 
 <img alt="暫無圖片" id="myImg" src="" height="100px" width="100px"> 
 </form>
 <script>
 function changImg(e){ 
 var myImg = document.getElementById('myImg');
 for (var i = 0; i < e.target.files.length; i++) { 
 var file = e.target.files[i]; 
 console.log(file); 
 if (!(/^image\/.*$/i.test(file.type))) { 
  continue; //不是圖片 就跳出這一次循環(huán) 
 } 
 //實(shí)例化FileReader API 
 var freader = new FileReader(); 
 freader.readAsDataURL(file); 
 freader.onload = function(e) { 
  console.log(e);
  myImg.setAttribute('src', e.target.result); 
 } 
 } 
 }
 </script>
</body>
</html>

后記

      通過這件事就暴露了我學(xué)習(xí)新東西的一個(gè)問題,就是查出來看一遍覺得知道了就行了,這種習(xí)慣是特別害人的,以后每當(dāng)有個(gè)疑問查出來之后不僅要查是怎么做的,還要了解一下為什么可以這么做,所謂知其然知其所以然。還有就是平時(shí)的代碼能用手敲的盡量別復(fù)制,復(fù)制一時(shí)是爽了,可要手寫的時(shí)候?qū)懖怀鰜硪彩锹爩擂蔚摹?/p>

      今天是來杭州的第三天,面試的第二天,這兩天的面試中暴露出的一個(gè)重要問題就是平時(shí)太依賴搜索引擎,用腦太少,連一些簡(jiǎn)單API就沒記全,前端確實(shí)還是有很多東西就是要牢牢記住的,沒什么捷徑可走,這些東西就是基礎(chǔ),沒記住就是基礎(chǔ)差。雖然你并不影響你做出東西來,但會(huì)影響開發(fā)效率,技術(shù)要往上走,這個(gè)基石必須穩(wěn),加油記吧!

總結(jié)

以上所述是小編給大家介紹的JS中利用FileReader實(shí)現(xiàn)上傳圖片前本地預(yù)覽,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • JavaScript內(nèi)置對(duì)象Math與String詳細(xì)介紹

    JavaScript內(nèi)置對(duì)象Math與String詳細(xì)介紹

    這篇文章主要介紹了JavaScript內(nèi)置對(duì)象Math與String的介紹與使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • javascript 高級(jí)語法之繼承的基本使用方法示例

    javascript 高級(jí)語法之繼承的基本使用方法示例

    這篇文章主要介紹了javascript 高級(jí)語法之繼承的基本使用方法,結(jié)合實(shí)例形式分析了JavaScript繼承的基本使用方法與操作注意事項(xiàng),需要的朋友可以參考下
    2019-11-11
  • 詳解JS如何處理可視區(qū)域圖片懶加載技巧

    詳解JS如何處理可視區(qū)域圖片懶加載技巧

    這篇文章主要為大家介紹了JS如何處理可視區(qū)域圖片懶加載技巧詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-06-06
  • js屏蔽退格鍵(backspace或者叫后退鍵與F5)

    js屏蔽退格鍵(backspace或者叫后退鍵與F5)

    今天有工作人員反饋后臺(tái)編輯文章的時(shí)候,多按了幾下退格鍵,然后當(dāng)前編輯的頁面都返回到上一頁了,導(dǎo)致剛剛添加的內(nèi)容全部丟失,今天正好有空給整理一下
    2019-02-02
  • javascript 跨域問題以及解決辦法

    javascript 跨域問題以及解決辦法

    這篇文章主要介紹了javascript 跨域問題以及解決辦法的相關(guān)資料,需要的朋友可以參考下
    2017-07-07
  • js獲取ip和地區(qū)

    js獲取ip和地區(qū)

    本文主要介紹了js獲取ip和地區(qū)的方法,具有很好的參考價(jià)值。下面跟著小編一起來看下吧
    2017-03-03
  • bootstrap daterangepicker漢化以及擴(kuò)展功能

    bootstrap daterangepicker漢化以及擴(kuò)展功能

    這篇文章主要為大家詳細(xì) 介紹了bootstrap daterangepicker漢化以及擴(kuò)展功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • js使用對(duì)象直接量創(chuàng)建對(duì)象的代碼

    js使用對(duì)象直接量創(chuàng)建對(duì)象的代碼

    js使用對(duì)象直接量創(chuàng)建對(duì)象的代碼...
    2007-09-09
  • JavaScript編寫猜拳游戲

    JavaScript編寫猜拳游戲

    這篇文章主要為大家詳細(xì)介紹了JavaScript編寫猜拳游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • JavaScript學(xué)習(xí)筆記之創(chuàng)建對(duì)象

    JavaScript學(xué)習(xí)筆記之創(chuàng)建對(duì)象

    在JavaScript中對(duì)象是一種基本的數(shù)據(jù)類型,在數(shù)據(jù)結(jié)構(gòu)上是一種散列表,可以看作是屬性的無序集合,除了原始值其他一切都是對(duì)象。這篇文章主要給大家介紹JavaScript學(xué)習(xí)筆記之創(chuàng)建對(duì)象,需要的朋友參考下吧
    2016-03-03

最新評(píng)論