本篇文章給大家分享的是有關vue中怎么實現(xiàn)一個上傳圖片組件,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
1.首先得有一個[type=file]文件標簽并且隱藏,changge事件來獲取圖片:
<input @change="fileChange($event)" type="file" id="upload_file" multiple />
2.觸發(fā)隱藏的文件標簽:(通過原生的click來觸發(fā))
document.getElementById('upload_file').click()
3.獲取file文件里面的值方法:fileChange($event)
fileChange(el){ if (!el.target.files[0].size) return;//判斷是否有文件數(shù)量 this.fileList(el.target.files);//獲取files文件組傳入處理 el.target.value = ''//清空val值,以便可以重復添加一張圖片 }
4.處理files文件組
獲取傳入單個圖片文件
fileList(files){ for (let i = 0; i < files.length; i++) { this.fileAdd(files[i]); } }
處理獲取到的圖片文件,統(tǒng)計文件大小,轉(zhuǎn)圖片為base64以供顯示
fileAdd(file){ this.size = this.size + file.size;//總大小 let reader = new FileReader(); reader.vue = this; reader.readAsDataURL(file); reader.onload = function () { file.src = this.result; this.vue.imgList.push({ file }); } },
5.文件大小換算
bytesToSize(bytes){ if (bytes === 0) return '0 B'; let k = 1000, // or 1024 sizes = ['B', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'], i = Math.floor(Math.log(bytes) / Math.log(k)); return (bytes / Math.pow(k, i)).toPrecision(3) + ' ' + sizes[i]; },
6.拖拽上傳
<div class="upload_warp_right" @drop="drop($event)" @dragenter="dragenter($event)" @dragover="dragover($event)"> 或者將文件拖到此處 </div>
dragenter(el){ el.stopPropagation(); el.preventDefault(); }, dragover(el){ el.stopPropagation(); el.preventDefault(); }, drop(el){ el.stopPropagation(); el.preventDefault(); this.fileList(el.dataTransfer.files); }
最終效果如下:
以上就是vue中怎么實現(xiàn)一個上傳圖片組件,小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降?。希望你能通過這篇文章學到更多知識。更多詳情敬請關注創(chuàng)新互聯(lián)網(wǎng)站建設公司行業(yè)資訊頻道。
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)建站aaarwkj.com,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
本文標題:vue中怎么實現(xiàn)一個上傳圖片組件-創(chuàng)新互聯(lián)
當前路徑:http://aaarwkj.com/article26/dipgjg.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供用戶體驗、靜態(tài)網(wǎng)站、網(wǎng)站改版、網(wǎng)站營銷、手機網(wǎng)站建設、品牌網(wǎng)站設計
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)