element-ui中up-load組件實(shí)現(xiàn)圖片上傳回顯
方式一:直接上傳(auto-upload=“true”)
一:前端樣式以及效果:

前端樣式代碼如下:
<template>
<div>
<el-upload action="api/admin/file/uploadfoodpicture" list-type="picture-card" auto-upload="true"
:on-success="sucuploadimg">
<i class="el-icon-plus"></i>
</el-upload>
<img :src="imgUrl" alt="圖" />
</div>
</template>
<script>
export default {
data() {
return {
imgUrl: ''
};
},
methods: {
sucuploadimg(res) {
this.imgUrl = res.data;
}
}
}
</script>
二:后端Controller層
@RestController
@RequestMapping("/admin/file")
@Slf4j
@Api(value = "文件相關(guān)接口",tags = {"文件相關(guān)接口操作接口"})
public class filecontroller {
@PostMapping("/uploadfoodpicture")
@ApiOperation("上傳食物圖片")
public Result uploadFoodPicture(@RequestBody MultipartFile file) throws Exception {
//獲取圖片原文件名
log.info("啟動(dòng)圖片上傳功能");
String url= FileUtil.uploadimg(file);//將傳遞的圖片交給FileUtil處理
return Result.success(200,"上傳圖片成功",url);
}
}這里的處理邏輯是將前端傳遞進(jìn)來的圖片交給FileUtil處理,接下來看FileUtil的代碼:
@Component
public class FileUtil {
public static String imgsrc = "D:\\image\\";
public static String uploadimg(MultipartFile file) throws IOException {
String originalFilename = file.getOriginalFilename();
//獲取原文件的后綴名
if (originalFilename != null) {
String fileExtension = originalFilename.substring(originalFilename.lastIndexOf("."));
String uuid = UUID.randomUUID().toString();
// 使用UUID和文件擴(kuò)展名來創(chuàng)建一個(gè)新的文件名
String newFilename = uuid + fileExtension;
file.transferTo(new File(FileUtil.imgsrc + newFilename));
String url ="http://localhost:8080"+"/uploadimg/" +newFilename;
return url;
}
return "上傳失敗";
}
}首先獲取傳遞進(jìn)來圖片的文件名后綴 然后用UUID將其拼接得到一個(gè)新的名字
將圖片存入到本地的文件夾下面 接下來返回路徑 這里我用后端進(jìn)行拼接,看看這三個(gè)參數(shù):
"http://localhost:8080"+"/uploadimg/" +newFilename;
其中"http://localhost:8080"是服務(wù)器端口號(hào)地址 根據(jù)環(huán)境進(jìn)行變化,也可以拼接在前端
"/uploadimg/"是攔截器的關(guān)鍵詞 一會(huì)進(jìn)行介紹
newFilename是經(jīng)過UUID拼接后的新文件名
我們接下來看看攔截器:在config文件夾下新建
@Configuration
@EnableWebMvc
public class MvcConfig implements WebMvcConfigurer {
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
// 配置靜態(tài)資源映射
registry.addResourceHandler("/uploadimg/**")
.addResourceLocations("file:///"+ FileUtil.imgsrc);
}
}攔截到路徑為/uploadimg/**后會(huì)替換為下面的地址 而file:///是固定的,F(xiàn)ileUtil.imgsrc是在FileUtil里面定義的存儲(chǔ)圖片的地址
到此后端的準(zhǔn)備工作也完畢了
點(diǎn)擊上傳圖片

到此這篇關(guān)于element-ui中up-load組件實(shí)現(xiàn)圖片上傳回顯的文章就介紹到這了,更多相關(guān)element up-load圖片上傳回顯內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue Element前端應(yīng)用開發(fā)之常規(guī)Element界面組件
在我們開發(fā)BS頁面的時(shí)候,往往需要了解常規(guī)界面組件的使用,小到最普通的單文本輸入框、多文本框、下拉列表,以及按鈕、圖片展示、彈出對(duì)話框、表單處理、條碼二維碼等等,本篇隨筆基于普通表格業(yè)務(wù)的展示錄入的場(chǎng)景介紹這些常規(guī)Element組件的使用2021-05-05
vue項(xiàng)目打包優(yōu)化方式(讓打包的js文件變小)
這篇文章主要介紹了vue項(xiàng)目打包優(yōu)化方式(讓打包的js文件變小),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04
vue實(shí)現(xiàn)個(gè)人信息查看和密碼修改功能
本文通過實(shí)例代碼給大家介紹了vue實(shí)現(xiàn)個(gè)人信息查看和密碼修改功能,文中給大家補(bǔ)充介紹了vue實(shí)現(xiàn)密碼顯示隱藏切換功能,非常不錯(cuò),具有一定的參考借鑒價(jià)值,感興趣的朋友一起看看吧2018-05-05
vue?element-plus中el-input修改邊框border的方法
element樣式還是蠻好的,只是有時(shí)候我們需要做一些調(diào)整,比如el-input的邊框,下面這篇文章主要給大家介紹了關(guān)于vue?element-plus中el-input修改邊框border的相關(guān)資料,需要的朋友可以參考下2022-09-09
詳解vue項(xiàng)目中實(shí)現(xiàn)圖片裁剪功能
這篇文章主要介紹了vue項(xiàng)目中實(shí)現(xiàn)圖片裁剪功能,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06
解決Vue項(xiàng)目Network:?unavailable的問題
項(xiàng)目只能通過Local訪問而不能通過Network訪問,本文主要介紹了解決Vue項(xiàng)目Network:?unavailable的問題,具有一定的參考價(jià)值,感興趣的可以了解一下2024-06-06

