Vue中如何使用ElementUI實(shí)現(xiàn)圖片上傳
一、前端代碼實(shí)現(xiàn)
廢話不多說直接上代碼
<el-form-item prop="image" label="上傳圖片" v-model="form.image"> <el-upload :action="'http://localhost:8080/files/upload'" list-type="picture-card" limit="1" :on-exceed="limitError" :on-success="imgSuccess" :on-error="imgError" > <i class="el-icon-plus"></i> </el-upload> </el-form-item>
這里用了elementUI的一個(gè)簡單的例子,自己又改了一些,簡單講解一下
action: 頭像上傳向后端發(fā)送的地址,這里后端采用了本地上傳
list-type: 即文件列表的類型,就是上傳后文件的樣式是圖片還是文字的格式
limit: 上傳數(shù)量的限制,這里僅可上傳一張圖片
on-exceed: 上傳超過限制觸發(fā)的函數(shù)
on-success: 上傳成功觸發(fā)的函數(shù)
on-error: 上傳失敗觸發(fā)的函數(shù)
更多參數(shù)可以參照:組件 | Element
相對(duì)應(yīng)的函數(shù)如下:
// 上傳成功 imgSuccess(res, file) { this.imageUrl = res.data; this.form.image = this.imageUrl; console.log(res.data); }, // 上傳失敗 imgError(res) { this.$message({ type: "error", message: "附件上傳失敗", }); }, // 上傳數(shù)量超限 limitError() { this.$message({ type: "error", message: "圖片僅可上傳一張", }); },
比較重要的是上傳成功后的函數(shù)imgSuccess,此函數(shù)需要根據(jù)實(shí)際項(xiàng)目中你的form表單的值或者構(gòu)建的data進(jìn)行綁定操作,確保圖片地址能被后端存儲(chǔ)便于后續(xù)展示
二、后端代碼實(shí)現(xiàn)
/** * 文件上傳 */ @PostMapping("/upload") public Result upload(MultipartFile file) { if(file == null || file.isEmpty()) { return Result.error(400,"上傳文件為空"); } String flag; synchronized (FileController.class) { flag = System.currentTimeMillis() + ""; ThreadUtil.sleep(1L); } String fileName = file.getOriginalFilename(); try { if (!FileUtil.isDirectory(filePath)) { FileUtil.mkdir(filePath); } // 文件存儲(chǔ)形式:時(shí)間戳-文件名 FileUtil.writeBytes(file.getBytes(), filePath + flag + "-" + fileName); System.out.println(fileName + "--上傳成功"); System.out.println("文件上傳地址"+filePath); } catch (Exception e) { System.err.println(fileName + "--文件上傳失敗"); return Result.error(400,"文件上傳失敗"); } String http = "http://" + ip + ":" + port + "/files/"; return Result.success(http + flag + "-" + fileName); }
很普通的一個(gè)文件上傳接口,僅接收一個(gè)文件流并進(jìn)行本地存儲(chǔ)后名稱為:時(shí)間戳-文件名,
后端進(jìn)行測試沒有問題
三、調(diào)試效果實(shí)現(xiàn)
前端顯示圖片上傳成功
到此這篇關(guān)于Vue中如何使用ElementUI實(shí)現(xiàn)圖片上傳的文章就介紹到這了,更多相關(guān)ElementUI圖片上傳內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue路由事件beforeRouteLeave及組件內(nèi)定時(shí)器的清除方法
今天小編就為大家分享一篇vue路由事件beforeRouteLeave及組件內(nèi)定時(shí)器的清除方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-09-09vue使用window.open()跳轉(zhuǎn)頁面的代碼案例
這篇文章主要介紹了vue中對(duì)window.openner的使用,vue使用window.open()跳轉(zhuǎn)頁面的代碼案例,本文通過實(shí)例代碼給大家詳細(xì)講解,需要的朋友可以參考下2022-11-11Vue 實(shí)現(xiàn)點(diǎn)擊空白處隱藏某節(jié)點(diǎn)的三種方式(指令、普通、遮罩)
最近小編接到這樣的需求:彈出框(或Popover)在 show 后,點(diǎn)擊空白處可以將其 hide。針對(duì)這個(gè)需求,小編整理了三種實(shí)現(xiàn)方式,如果大家對(duì)vue 點(diǎn)擊空白隱藏節(jié)點(diǎn)問題感興趣的朋友跟隨小編一起看看吧2019-10-10vue+element-ui:使用el-dialog時(shí)彈框不出現(xiàn)的解決
這篇文章主要介紹了vue+element-ui:使用el-dialog時(shí)彈框不出現(xiàn)的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10基于vue的短信驗(yàn)證碼倒計(jì)時(shí)demo
這篇文章主要介紹了基于vue的短信驗(yàn)證碼倒計(jì)時(shí)demo,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-09-09vue子組件使用自定義事件向父組件傳遞數(shù)據(jù)
這篇文章主要介紹了vue子組件使用自定義事件向父組件傳遞數(shù)據(jù)的方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-05-05