js實(shí)現(xiàn)前端圖片上傳即時(shí)預(yù)覽功能
現(xiàn)在,在實(shí)現(xiàn)前端圖片即時(shí)預(yù)覽,可以說是一件很簡單的事情了。
我們只需要用file對象和FileReader對象,既可以輕松實(shí)現(xiàn),無需下載類庫。
HTML代碼
<!DOCTYPE html> <html> <body> <img src=""> <form> <input type="file" name="image" /> </form> </body> </html>
先來說說input,input這個(gè)元素,具有一個(gè)files屬性,該屬性是一個(gè)filelist對象,是file對象的集合。
你可以通過input.files[0]的語法形式拿到這個(gè)file對象,不過遺憾的是,這個(gè)對象僅僅包含了用戶選擇的文件的相關(guān)信息,如文件名,大小,類型,最后修改時(shí)間等,并不直接提供文件的數(shù)據(jù)。
程序員只能通過這些信息對用戶選擇的文件進(jìn)行一些限制。
所以,我們要使用另一個(gè)對象FileReader來讀取到用戶選擇的文件的數(shù)據(jù)
我們初始化一個(gè)FileReader對象
var x=new FileReader;
這是一個(gè)初始化完成的FileReader對象具有的一些屬性和支持的事件

類似于Ajax,F(xiàn)ileReader提供了readyState來查看讀取的狀態(tài),不過并沒有什么卵用
因?yàn)镕ileReader還提供了onloadend這樣的事件,來處理數(shù)據(jù)讀取完成后該干些什么,onprogress是最有趣的,只要在讀取數(shù)據(jù),那么這個(gè)事件會被不停的觸發(fā),可以實(shí)現(xiàn)那種進(jìn)度條效果。
還有一個(gè)極其重要的屬性result,初始化完成時(shí),該值是null,當(dāng)讀取數(shù)據(jù)后,該值就是所獲得的數(shù)據(jù)。
接下來,我們就可以使用這個(gè)對象讀取用戶選擇的圖片了,沒有錯(cuò)就是這么簡單
當(dāng)用戶選擇了某一個(gè)文件時(shí),就會在input上觸發(fā)change事件,這意味著我們可以開始讀取數(shù)據(jù)了
document.forms[0].elements[0].onchange=function(){
x.readAsDataURL(this.files[0]);
}
readASDateURL這個(gè)方法,可以讀取一個(gè)file對象,并把數(shù)據(jù)以base64的格式填充到FileReader對象中的result屬性中去。
當(dāng)數(shù)據(jù)讀取完畢,就會觸發(fā)onloadend事件,在這個(gè)事件中,就可以把數(shù)據(jù)填到img標(biāo)簽中去
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>
當(dāng)然,這里只是一個(gè)小小的Demo,僅僅實(shí)現(xiàn)了本地預(yù)覽,拋磚引玉,你還可以在此基礎(chǔ)上輕松實(shí)現(xiàn)對上傳文件的一些判斷和限制,或者是UI上的提升。
FileReader的能力并不止步于此,不僅僅有readASDataURL這種方法。

不僅是圖片,音樂,視頻都可以實(shí)現(xiàn)對于的本地預(yù)覽,只要把result屬性的值,賦值給對應(yīng)的audio或video標(biāo)簽的src屬性即可,不過因?yàn)閮?nèi)存限制,讀取視頻往往失敗。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
js 點(diǎn)擊頁面其他地方關(guān)閉彈出層(示例代碼)
本篇文章主要介紹了js點(diǎn)擊頁面其他地方關(guān)閉彈出層的示例代碼。需要的朋友可以過來參考下,希望對大家有所幫助2013-12-12
分享JavaScript監(jiān)聽全部Ajax請求事件的方法
最近在做一個(gè)小項(xiàng)目,引入了第三方j(luò)s文件,這個(gè)文件會調(diào)用XMLHttpRequest向服務(wù)器發(fā)送 Ajax請求,但是我有需要監(jiān)聽其Ajax請求的某些事件,以便額外地執(zhí)行其他腳本。于是稍微看了看監(jiān)聽 Ajax請求的事件方法,在這里分享給大家。有需要的朋友們可以參考借鑒。2016-08-08
不用typsescript如何使用類型增強(qiáng)功能
這篇文章主要給大家介紹了關(guān)于不用typsescript如何使用類型增強(qiáng)功能的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03
微信小程序賬號密碼登入和傳值的實(shí)現(xiàn)方法
傳統(tǒng)的web開發(fā)實(shí)現(xiàn)登陸功能,一般的做法是輸入賬號密碼、或者輸入手機(jī)號及短信驗(yàn)證碼進(jìn)行登錄,下面這篇文章主要給大家介紹了關(guān)于微信小程序賬號密碼登入和傳值的實(shí)現(xiàn)方法,需要的朋友可以參考下2022-04-04
JavaScript 隱式類型轉(zhuǎn)換規(guī)則詳解
這篇文章主要為大家介紹了JavaScript 隱式類型轉(zhuǎn)換規(guī)則詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2023-05-05

