国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

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

2024-05-06 15:21:12
字體:
供稿:網(wǎng)友

引子

      平時(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對象

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

event.target.files

核心是FileReader對象

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

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

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

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ū)懖怀鰜硪彩锹爩擂蔚摹?

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 香格里拉县| 宁国市| 视频| 兰州市| 三穗县| 连州市| 曲水县| 江源县| 通渭县| 吉安县| 安西县| 平和县| 彭山县| 宁强县| 虎林市| 临高县| 察雅县| 汕头市| 成都市| 青州市| 龙岩市| 扶沟县| 鄱阳县| 双辽市| 乌兰察布市| 获嘉县| 台前县| 玉屏| 全州县| 乌兰浩特市| 肃宁县| 安顺市| 绥滨县| 晴隆县| 志丹县| 门源| 博野县| 张北县| 巴南区| 广水市| 吴江市|