考慮到用戶體驗, 網(wǎng)頁的圖片上傳數(shù)據(jù)庫前,先預覽是很有必要的一個步驟,第一可以給用戶帶來安全感,第二防止圖片文件有問題而提交到數(shù)據(jù)庫,占用存儲資源。
成都創(chuàng)新互聯(lián)公司主營景縣網(wǎng)站建設的網(wǎng)絡公司,主營網(wǎng)站建設方案,手機APP定制開發(fā),景縣h5成都小程序開發(fā)搭建,景縣網(wǎng)站營銷推廣歡迎景縣等地區(qū)企業(yè)咨詢
那么要實現(xiàn)預覽有兩種方式:一種是用window.URL.createObjectURl方法對選擇的圖片數(shù)據(jù)(可以勉強理解為input的value)生成一個blob對象路徑,第二種是用獲取 FileReader讀取器。
那么無論那種方法,首先都得得到文件數(shù)據(jù),獲得文件數(shù)據(jù)是從files集合中獲取。
方式一:
代碼如下:
<input type=file id="inp"> <script> inp.onchange=function(){ var file=this.files[0] // 獲取input上傳的圖片數(shù)據(jù); var img=new Image() ; url=window.URL.createObjectURL(file) // 得到bolb對象路徑,可當成普通的文件路徑一樣使用,賦值給src; img.src=url; //其實也可一句代碼搞定,不需要聲明那么多變量;img.scr=window.URL.cteateObejectURL(this.files[0]) ; 然后把img添加到頁面就實現(xiàn)預覽了 } <script>
方式二:
用FileRader對像讀取文件.可分為四步;1、創(chuàng)建FileReader對像;2、調用readAsDataURL方法讀取文件;3、調用onload事件監(jiān)聽,我們一需要拿到完整的數(shù)據(jù),但我們又不知道文件何時讀完?,所以需要第三步監(jiān)聽;4、通過FileRader對像r的result屬性拿到讀取結果。
代碼如下:
<input type=file id="inp"> <input type=file id="inp"> <script> inp.onchange=function(){ var read=new FileReader() // 創(chuàng)建FileReader對像; read.readAsDataURL(this.files[0]) // 調用readAsDataURL方法讀取文件; read.onload=function(){ url=read.result // 拿到讀取結果; var img=new Image(); img.src=url; div.appendChild(img); } }
以上所述是小編給大家介紹的JS實現(xiàn)圖片預覽的幾種方式,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對創(chuàng)新互聯(lián)網(wǎng)站的支持!
當前標題:JS實現(xiàn)圖片預覽的兩種方式
文章起源:http://redsoil1982.com.cn/article4/gschie.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站維護、定制網(wǎng)站、ChatGPT、自適應網(wǎng)站、App設計、品牌網(wǎng)站設計
聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)