首頁 > web前端 > js教程 > 上傳圖片時本地先預覽如何實現

上傳圖片時本地先預覽如何實現

php中世界最好的语言
發布: 2018-03-17 11:53:44
原創
1986 人瀏覽過

這次帶給大家上傳圖片時本地先預覽如何實現,實現上傳圖片時本地先預覽的注意事項有哪些,下面就是實戰案例,一起來看一下。

FileReader 物件允許Web應用程式非同步讀取儲存在使用者電腦上的檔案(或原始資料緩衝區)的內容,使用 File 或 Blob 物件指定要讀取的檔案或資料。以下透過本文為大家介紹JS中利用FileReader實現上傳圖片前本地預覽功能,需要的朋友參考下

引子

      平時做圖片上傳預覽時如果沒有特殊的要求就直接先把圖片傳到後台去,成功之後拿到URL再渲染到頁面上,這樣做在圖片比較小的時候沒什麼問題,大一點的話就會比較慢才能看到預覽了,而且還產生了垃圾文件,所以比較好的是上傳之前先在本地預覽一下。

      之前做項找插件的時候就知道純前端可以實現圖片本地預覽,可今天面試的時候被問到時竟然一臉懵逼,然後竟然無意中就在電腦桌面發現了實現的demo,然後根據demo查了一下API,稍微總結一下:

首先得拿到File物件

      當用input標籤上傳圖片時event物件中會包含file物件的一個集合

event.target.files

核心是FileReader對象

根據MDN上的說法:

FileReader 物件允許網路應用程式非同步讀取儲存在使用者電腦上的檔案(或原始資料緩衝區)的內容,使用File 或Blob 物件指定要讀取的檔案或資料。

首先要作為建構子得到一個FileReader的實例物件

var freader = new FileReader();
登入後複製

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

freader.readAsDataURL(file);
登入後複製

最後就是一個事件處理,相當於監控讀取進度,我們這裡是當讀取完成時渲染圖片,所以用onload

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

這裡架加載完成之後最終得到的是一個base64編碼的src地址,具體為什麼下次查清楚了再專門寫篇關於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; //不是图片 就跳出这一次循环 
 } 
 //实例化FileReader API 
 var freader = new FileReader(); 
 freader.readAsDataURL(file); 
 freader.onload = function(e) { 
  console.log(e);
  myImg.setAttribute(&#39;src&#39;, e.target.result); 
 } 
 } 
 }
 </script>
</body>
</html>
登入後複製

相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

設定cookie過期自動更新和自動取得

使用import 和require打包JS

select的option疊加怎樣處理

以上是上傳圖片時本地先預覽如何實現的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板