JS中利用FileReader實現(xiàn)上傳圖片前本地預(yù)覽功能
引子
平時做圖片上傳預(yù)覽時如果沒有特殊的要求就直接先把圖片傳到后臺去,成功之后拿到URL再渲染到頁面上,這樣做在圖片比較小的時候沒什么問題,大一點的話就會比較慢才能看到預(yù)覽了,而且還產(chǎn)生了垃圾文件,所以比較好的是上傳之前先在本地預(yù)覽一下。
之前做項找插件的時候就知道純前端可以實現(xiàn)圖片本地預(yù)覽,可今天面試的時候被問到時竟然一臉懵逼,然后竟然無意中就在電腦桌面發(fā)現(xiàn)了實現(xiàn)的demo,然后根據(jù)demo查了一下API,稍微總結(jié)下:
首先得拿到File對象
當用input標簽上傳圖片時event對象中會包含file對象的一個集合
event.target.files
核心是FileReader對象
根據(jù)MDN上的說法:
FileReader 對象允許Web應(yīng)用程序異步讀取存儲在用戶計算機上的文件(或原始數(shù)據(jù)緩沖區(qū))的內(nèi)容,使用 File 或 Blob 對象指定要讀取的文件或數(shù)據(jù)。
首先要作為構(gòu)造函數(shù)得到一個FileReader的實例對象
var freader = new FileReader();
利用readAsDataURL()方法讀取指定的內(nèi)容
freader.readAsDataURL(file);
最后就是一個事件處理,相當于監(jiān)控讀取進度,我們這里是當讀取完成時渲染圖片,所以用onload
freader.onload = function(e) { console.log(e); myImg.setAttribute('src', e.target.result); }
這里架加載完成之后最終得到的是一個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)
}
//實例化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í)新東西的一個問題,就是查出來看一遍覺得知道了就行了,這種習(xí)慣是特別害人的,以后每當有個疑問查出來之后不僅要查是怎么做的,還要了解一下為什么可以這么做,所謂知其然知其所以然。還有就是平時的代碼能用手敲的盡量別復(fù)制,復(fù)制一時是爽了,可要手寫的時候?qū)懖怀鰜硪彩锹爩擂蔚摹?/p>
今天是來杭州的第三天,面試的第二天,這兩天的面試中暴露出的一個重要問題就是平時太依賴搜索引擎,用腦太少,連一些簡單API就沒記全,前端確實還是有很多東西就是要牢牢記住的,沒什么捷徑可走,這些東西就是基礎(chǔ),沒記住就是基礎(chǔ)差。雖然你并不影響你做出東西來,但會影響開發(fā)效率,技術(shù)要往上走,這個基石必須穩(wěn),加油記吧!
總結(jié)
以上所述是小編給大家介紹的JS中利用FileReader實現(xiàn)上傳圖片前本地預(yù)覽,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- javascript結(jié)合fileReader 實現(xiàn)上傳圖片
- JavaScript通過filereader接口讀取文件
- JS+HTML5 FileReader對象用法示例
- JS+HTML5 FileReader實現(xiàn)文件上傳前本地預(yù)覽功能
- JavaScript html5利用FileReader實現(xiàn)上傳功能
- 原生js FileReader對象實現(xiàn)圖片上傳本地預(yù)覽效果
- JavaScript使用FileReader實現(xiàn)圖片上傳預(yù)覽效果
- 基于JavaScript FileReader上傳圖片顯示本地鏈接
- JS中FileReader類實現(xiàn)文件上傳及時預(yù)覽功能
- JavaScript中的FileReader示例詳解
相關(guān)文章
javascript 哈希表(hashtable)的簡單實現(xiàn)
javascript中沒有像c#,java那樣的哈希表(hashtable)的實現(xiàn)。在js中,object屬性的實現(xiàn)就是hash表,因此只要在object上封裝點方法,簡單的使用obejct管理屬性的方法就可以實現(xiàn)簡單高效的hashtable。2010-01-01
javascript 刪除dom對象的事件函數(shù)代碼
本文為《JavaScript高級程序設(shè)計》第9章中的跨平臺事件中的部分內(nèi)容。2010-04-04
Chrome不支持showModalDialog模態(tài)對話框和無法返回returnValue問題的解決方法
上個禮拜修改測試一個后臺管理項目,在測試與各個瀏覽器兼容性的時候,發(fā)現(xiàn)在chrome瀏覽器下showModalDialog方法顯示的并不是模態(tài)對話框,就像新打開一個頁面一樣,父窗口仍然可以隨意獲取焦點,并可以打開多個窗體,而且返回值returnValue也無法返回,一直是undefined2016-10-10
js 實現(xiàn)獲取name 相同的頁面元素并循環(huán)遍歷的方法
下面小編就為大家?guī)硪黄猨s 實現(xiàn)獲取name 相同的頁面元素并循環(huán)遍歷的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02
uniapp插件uview下表單無法動態(tài)校驗的問題解決
最近項目中用到了uview?在做表單時用到了校驗,發(fā)現(xiàn)校驗不友好的結(jié)果,下面這篇文章主要給大家介紹了關(guān)于uniapp插件uview下表單無法動態(tài)校驗的問題解決,需要的朋友可以參考下2022-12-12

