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

Vue中如何使用ElementUI實(shí)現(xiàn)圖片上傳

 更新時(shí)間:2024年03月21日 09:08:36   作者:奈何不吃魚  
這篇文章主要介紹了Vue中如何使用ElementUI實(shí)現(xiàn)圖片上傳,這里用了elementUI的一個(gè)簡單的例子,給大家介紹的非常詳細(xì),需要的朋友可以參考下

一、前端代碼實(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雙向綁定及觀察者模式詳解

    vue雙向綁定及觀察者模式詳解

    這篇文章主要介紹了vue雙向綁定及觀察者模式,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • vue路由事件beforeRouteLeave及組件內(nèi)定時(shí)器的清除方法

    vue路由事件beforeRouteLeave及組件內(nèi)定時(shí)器的清除方法

    今天小編就為大家分享一篇vue路由事件beforeRouteLeave及組件內(nèi)定時(shí)器的清除方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • vue使用window.open()跳轉(zhuǎn)頁面的代碼案例

    vue使用window.open()跳轉(zhuǎn)頁面的代碼案例

    這篇文章主要介紹了vue中對(duì)window.openner的使用,vue使用window.open()跳轉(zhuǎn)頁面的代碼案例,本文通過實(shí)例代碼給大家詳細(xì)講解,需要的朋友可以參考下
    2022-11-11
  • Vue 實(shí)現(xiàn)點(diǎn)擊空白處隱藏某節(jié)點(diǎn)的三種方式(指令、普通、遮罩)

    Vue 實(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-10
  • vue+element-ui:使用el-dialog時(shí)彈框不出現(xiàn)的解決

    vue+element-ui:使用el-dialog時(shí)彈框不出現(xiàn)的解決

    這篇文章主要介紹了vue+element-ui:使用el-dialog時(shí)彈框不出現(xiàn)的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • 如何利用vue實(shí)現(xiàn)波譜擬合詳解

    如何利用vue實(shí)現(xiàn)波譜擬合詳解

    這篇文章主要給大家介紹了關(guān)于如何利用vue實(shí)現(xiàn)波譜擬合的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • Vue使用插槽實(shí)現(xiàn)高復(fù)用組件

    Vue使用插槽實(shí)現(xiàn)高復(fù)用組件

    在現(xiàn)代前端開發(fā)中,組件化開發(fā)已經(jīng)成為主流,其中?Vue.js?的插槽(slots)特性為我們構(gòu)建靈活、可復(fù)用的組件提供了強(qiáng)有力的支持,下面我們就來看看Vue如何通過插槽實(shí)現(xiàn)高復(fù)用組件吧
    2024-11-11
  • 基于vue的短信驗(yàn)證碼倒計(jì)時(shí)demo

    基于vue的短信驗(yàn)證碼倒計(jì)時(shí)demo

    這篇文章主要介紹了基于vue的短信驗(yàn)證碼倒計(jì)時(shí)demo,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-09-09
  • Vue2 的12種組件通訊

    Vue2 的12種組件通訊

    之前文章我們描述給過Vue3 的七通信使用,今天中五篇文章我們?cè)賮砜纯碫ue2 的通信使用寫法的相關(guān)資料,需要的朋友可以參考下面文章的具體內(nèi)容
    2021-09-09
  • vue子組件使用自定義事件向父組件傳遞數(shù)據(jù)

    vue子組件使用自定義事件向父組件傳遞數(shù)據(jù)

    這篇文章主要介紹了vue子組件使用自定義事件向父組件傳遞數(shù)據(jù)的方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-05-05

最新評(píng)論