欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

element-ui中up-load組件實(shí)現(xiàn)圖片上傳回顯

 更新時(shí)間:2024年01月26日 11:39:20   作者:加洛斯  
在項(xiàng)目開(kāi)發(fā)的時(shí)候很多人都會(huì)用到圖片上傳,本文主要介紹了element-ui中up-load組件實(shí)現(xiàn)圖片上傳回顯,具有一定的參考價(jià)值,感興趣的可以了解一下

方式一:直接上傳(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)來(lái)的圖片交給FileUtil處理,接下來(lái)看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ò)展名來(lái)創(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)來(lái)圖片的文件名后綴 然后用UUID將其拼接得到一個(gè)新的名字

將圖片存入到本地的文件夾下面 接下來(lái)返回路徑 這里我用后端進(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)過(guò)UUID拼接后的新文件名

我們接下來(lái)看看攔截器:在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 router 源碼概覽案例分析

    vue router 源碼概覽案例分析

    這篇文章主要介紹了vue router 源碼概覽的案例分析,本文通過(guò)實(shí)例代碼案例分析給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-10-10
  • Vue Element前端應(yīng)用開(kāi)發(fā)之常規(guī)Element界面組件

    Vue Element前端應(yīng)用開(kāi)發(fā)之常規(guī)Element界面組件

    在我們開(kāi)發(fā)BS頁(yè)面的時(shí)候,往往需要了解常規(guī)界面組件的使用,小到最普通的單文本輸入框、多文本框、下拉列表,以及按鈕、圖片展示、彈出對(duì)話(huà)框、表單處理、條碼二維碼等等,本篇隨筆基于普通表格業(yè)務(wù)的展示錄入的場(chǎng)景介紹這些常規(guī)Element組件的使用
    2021-05-05
  • vue項(xiàng)目打包優(yōu)化方式(讓打包的js文件變小)

    vue項(xiàng)目打包優(yōu)化方式(讓打包的js文件變小)

    這篇文章主要介紹了vue項(xiàng)目打包優(yōu)化方式(讓打包的js文件變小),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue實(shí)現(xiàn)個(gè)人信息查看和密碼修改功能

    vue實(shí)現(xiàn)個(gè)人信息查看和密碼修改功能

    本文通過(guò)實(shí)例代碼給大家介紹了vue實(shí)現(xiàn)個(gè)人信息查看和密碼修改功能,文中給大家補(bǔ)充介紹了vue實(shí)現(xiàn)密碼顯示隱藏切換功能,非常不錯(cuò),具有一定的參考借鑒價(jià)值,感興趣的朋友一起看看吧
    2018-05-05
  • vue?element-plus中el-input修改邊框border的方法

    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中關(guān)于重新渲染組件的方法及總結(jié)

    Vue中關(guān)于重新渲染組件的方法及總結(jié)

    這篇文章主要介紹了Vue中關(guān)于重新渲染組件的方法及總結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • vue實(shí)現(xiàn)懸浮球效果

    vue實(shí)現(xiàn)懸浮球效果

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)懸浮球效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • vue中配置scss全局變量的步驟

    vue中配置scss全局變量的步驟

    這篇文章主要介紹了vue中配置scss全局變量的步驟,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下
    2020-12-12
  • 詳解vue項(xiàng)目中實(shí)現(xiàn)圖片裁剪功能

    詳解vue項(xiàng)目中實(shí)現(xiàn)圖片裁剪功能

    這篇文章主要介紹了vue項(xiàng)目中實(shí)現(xiàn)圖片裁剪功能,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • 解決Vue項(xiàng)目Network:?unavailable的問(wèn)題

    解決Vue項(xiàng)目Network:?unavailable的問(wèn)題

    項(xiàng)目只能通過(guò)Local訪問(wèn)而不能通過(guò)Network訪問(wèn),本文主要介紹了解決Vue項(xiàng)目Network:?unavailable的問(wèn)題,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-06-06

最新評(píng)論