vue實(shí)現(xiàn)文件上傳
本文實(shí)例為大家分享了vue實(shí)現(xiàn)文件上傳的具體代碼,供大家參考,具體內(nèi)容如下
記錄問題,方便回顧
1、使用elementUI的 el-upload插件進(jìn)行上傳。 2、使用input。
1、使用elementUI的 el-upload插件進(jìn)行上傳。
html:
<el-upload ? ? ref="avatar-uploader" ? ? class="avatar-uploader" ? ? :show-file-list="false" ? ? :auto-upload="false" ? ? action ? ? :on-change="handleChange" ? > ? ?<img v-if="AddSubmenuData.imageUrl" :src="AddSubmenuData.imageUrl" class="avatar"> ? ?<i v-else class="el-icon-plus avatar-uploader-icon"></i> </el-upload>
js:
data() { ? ? ? return { ? ? ? ? AddSubmenuData:{ ? ? ? ? ? id:"", ? ? ? ? ? pid:"", ? ? ? ? ? funType:1, ? ? ? ? ? name:"", ? ? ? ? ? sort:"", ? ? ? ? ? SystemCoding:"", ? ? ? ? ? remarks:"", ? ? ? ? ? imageUrl: '' ? ? ? ? }, ? ? ? }; ? }, ? methods: { ? ?? ?// 獲取圖片信息并轉(zhuǎn)成base64 ? ? ? handleChange(file, fileList){ ? ? ? ?let reader = new FileReader(); ? ? ? ? let fileResult = ""; ? ? ? ? reader.readAsDataURL(file.raw); ? ? ? ? reader.onload = function() { ? ? ? ? ? fileResult = reader.result; ? ? ? ? }; ? ? ? ? reader.onloadend = function() { ? ? ? ? ? ?this.AddSubmenuData.imageUrl = fileResult ? ? ? ? }; ? ? ? } ? }
css:
?/deep/ ?.avatar-uploader .el-upload { ? ? ? border: 1px dashed #d9d9d9; ? ? ? border-radius: 6px; ? ? ? cursor: pointer; ? ? ? position: relative; ? ? ? overflow: hidden; ? ? ? margin-left: 80px; ? ? ? margin-bottom: 22px; ? ? } ? ? .avatar-uploader .el-upload:hover { ? ? ? border-color: #409EFF; ? ? } ? ? .avatar-uploader-icon { ? ? ? font-size: 28px; ? ? ? color: #8c939d; ? ? ? width: 178px; ? ? ? height: 178px; ? ? ? line-height: 178px; ? ? ? text-align: center; ? ? } ? ? .avatar { ? ? ? width: 178px; ? ? ? height: 178px; ? ? ? display: block; ? ? }
效果圖:
2、使用input進(jìn)行上傳。
1)、html
首先input的type屬性要改成file,如果需求是點(diǎn)擊按鈕在上傳文件。可以給input加一個(gè)ref=“fileInput”,然后通過點(diǎn)擊按鈕調(diào)用input的事件:@click="$refs.fileInput.click()".
<div class="el-button--primary el-button" @click="$refs.fileInput.click()"> ? ?<input type="file" ref="fileInput" accept="*" @change="getFile" style="display: none"> ? ?<img src="../../assets/Infrastructure/xz.png" />添加 </div>
2)、js
獲取文件后就可以進(jìn)行數(shù)據(jù)處理并調(diào)用接口。因?yàn)橛行r(shí)候,上傳文件有些是重復(fù)的,再次調(diào)用方法就是失效,所以,可以在每次上傳完之后清除之前上傳的文件,這樣即使文件相同,也可以重復(fù)調(diào)用方法。this.$refs.fileInput.value=’’
// 獲取文件數(shù)據(jù) ? getFile(event) { //這就是你上傳的文件 ? ? ? ?event.target.files[0] ? ? ? ? ? ? ? ?let formFile = new FormData(); ? ? ? ? formFile.append("file", event.target.files[0]); ? ? ? ? formFile.append("apply_info_id", this.RndNum(12)); ? ? ? ? formFile.append("file_type", ''); ? ? ? ? //調(diào)用接口 ? ? ? ? file_upload(formFile).then(res => { ? ? ? ? ? this.addInformation.addPoupTableData.data.push({name:res.data.name,id:res.data.id,size:(event.target.files[0].size/1024).toFixed(0) + "kb",path:res.data.path}) ? ? ? ? ? //調(diào)用接口后清除文件 ? ? ? ? ? this.$refs.fileInput.value='' ? ? ? ? }) ?},
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- vue實(shí)現(xiàn)文件上傳功能
- vue中使用input[type="file"]實(shí)現(xiàn)文件上傳功能
- SpringBoot+Vue.js實(shí)現(xiàn)前后端分離的文件上傳功能
- vue使用axios實(shí)現(xiàn)文件上傳進(jìn)度的實(shí)時(shí)更新詳解
- vue webuploader 文件上傳組件開發(fā)
- vue-cli+axios實(shí)現(xiàn)文件上傳下載功能(下載接收后臺(tái)返回文件流)
- vue中用H5實(shí)現(xiàn)文件上傳的方法實(shí)例代碼
- vue+vux實(shí)現(xiàn)移動(dòng)端文件上傳樣式
- vue實(shí)現(xiàn)文件上傳讀取及下載功能
- vue中實(shí)現(xiàn)圖片和文件上傳的示例代碼
相關(guān)文章
Vue生命周期activated之返回上一頁不重新請(qǐng)求數(shù)據(jù)操作
這篇文章主要介紹了Vue生命周期activated之返回上一頁不重新請(qǐng)求數(shù)據(jù)操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-07-07關(guān)于vue3+echart5?遇到的坑?Cannot?read?properties?of?undefine
這篇文章主要介紹了vue3+echart5?遇到的坑?Cannot?read?properties?of?undefined?(reading?'type'),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-04-04vue項(xiàng)目中引入noVNC遠(yuǎn)程桌面的方法
下面小編就為大家分享一篇vue項(xiàng)目中引入noVNC遠(yuǎn)程桌面的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-03-03詳解vue如何使用rules對(duì)表單字段進(jìn)行校驗(yàn)
這篇文章主要介紹了詳解vue如何使用rules對(duì)表單字段進(jìn)行校驗(yàn),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-10-10vue中defineProperty和Proxy的區(qū)別詳解
這篇文章主要介紹了vue中defineProperty和Proxy的區(qū)別詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11詳解無限滾動(dòng)插件vue-infinite-scroll源碼解析
這篇文章主要介紹了詳解無限滾動(dòng)插件vue-infinite-scroll源碼解析,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-05-05