vue上傳圖片組件編寫代碼
本文實例教大家如何編寫一個vue上傳圖片組件,具體如下
1.首先得有一個[type=file]文件標簽并且隱藏,changge事件來獲取圖片:
<input @change="fileChange($event)" type="file" id="upload_file" multiple style="display: none"/>
2.觸發(fā)隱藏的文件標簽:(通過原生的click來觸發(fā))
document.getElementById('upload_file').click()
3.獲取file文件里面的值方法:fileChange($event)
fileChange(el){ if (!el.target.files[0].size) return;//判斷是否有文件數量 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)計文件大小,轉圖片為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); }
最終效果如下:
點擊打開源碼 https://github.com/317482454/vue_upload
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
elementUI中el-dropdown的command實現傳遞多個參數
這篇文章主要介紹了elementUI中el-dropdown的command實現傳遞多個參數方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-08-08vue 實現cli3.0中使用proxy進行代理轉發(fā)
今天小編就為大家分享一篇vue 實現cli3.0中使用proxy進行代理轉發(fā),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10淺談vue實現數據監(jiān)聽的函數 Object.defineProperty
本篇文章主要介紹了淺談vue實現數據監(jiān)聽的函數 Object.defineProperty,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-06-06vue中如何動態(tài)綁定圖片,vue中通過data返回圖片路徑的方法
下面小編就為大家分享一篇vue中如何動態(tài)綁定圖片,vue中通過data返回圖片路徑的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-02-02