如今,在實現前端圖片即時預覽,能夠說是一件很簡單的事情了。javascript
咱們只須要用file對象和FileReader對象,既能夠輕鬆實現,無需下載類庫。html
HTML代碼前端
<!DOCTYPE html>
<html>
<body>
<img src="">
<form>
<input type="file" name="image" />
</form>
</body>
</html>
先來講說input,input這個元素,具備一個files屬性,該屬性是一個filelist對象,是file對象的集合。java
你能夠經過input.files[0]的語法形式拿到這個file對象,不過遺憾的是,這個對象僅僅包含了用戶選擇的文件的相關信息,如文件名,大小,類型,最後修改時間等,並不直接提供文件的數據。程序員
程序員只能經過這些信息對用戶選擇的文件進行一些限制。ide
因此,咱們要使用另外一個對象FileReader來讀取到用戶選擇的文件的數據this
咱們初始化一個FileReader對象spa
var x=new FileReader;
這是一個初始化完成的FileReader對象具備的一些屬性和支持的事件code
相似於Ajax,FileReader提供了readyState來查看讀取的狀態,不過並無什麼卵用orm
由於FileReader還提供了onloadend這樣的事件,來處理數據讀取完成後該幹些什麼,onprogress是最有趣的,只要在讀取數據,那麼這個事件會被不停的觸發,能夠實現那種進度條效果。
還有一個極其重要的屬性result,初始化完成時,該值是null,當讀取數據後,該值就是所得到的數據。
接下來,咱們就可使用這個對象讀取用戶選擇的圖片了,沒有錯就是這麼簡單
當用戶選擇了某一個文件時,就會在input上觸發change事件,這意味着咱們能夠開始讀取數據了
document.forms[0].elements[0].onchange=function(){ x.readAsDataURL(this.files[0]); }
readASDateURL這個方法,能夠讀取一個file對象,並把數據以base64的格式填充到FileReader對象中的result屬性中去。
當數據讀取完畢,就會觸發onloadend事件,在這個事件中,就能夠把數據填到img標籤中去
x.onloadend=function(){ document.images[0].src=this.result; }
完整版代碼
<!DOCTYPE html>
<html>
<body>
<img src="">
<form>
<input type="file" name="image" />
</form>
<script type="text/javascript">
var x=new FileReader; document.forms[0].elements[0].onchange=function(){ x.readAsDataURL(this.files[0]); } x.onloadend=function(){ document.images[0].src=this.result; } </script>
</body>
</html>
固然,這裏只是一個小小的Demo,僅僅實現了本地預覽,拋磚引玉,你還能夠在此基礎上輕鬆實現對上傳文件的一些判斷和限制,或者是UI上的提高。
FileReader的能力並不止步於此,不單單有readASDataURL這種方法。
不只是圖片,音樂,視頻均可以實現對於的本地預覽,只要把result屬性的值,賦值給對應的audio或video標籤的src屬性便可,不過由於內存限制,讀取視頻每每失敗。