成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

element-ui 中使用upload多文件上傳只請(qǐng)求一次接口

ethernet / 1854人閱讀

摘要:方法一不使用組件內(nèi)部的鉤子選取文件上傳到服務(wù)器只能上傳格式,大小不超過的圖片點(diǎn)擊上傳服務(wù)器的按鈕時(shí)調(diào)用這個(gè)函數(shù),也就是說不走的鉤子,不調(diào)用他的方法自己搞在這里對(duì)每一張圖片進(jìn)行大小的校驗(yàn),如果不符合則提示,所有不符合的都提示

方法一
不使用組件內(nèi)部的鉤子


  選取文件
  上傳到服務(wù)器
  
只能上傳jpg、png、gif 格式,大小不超過500KB的圖片

js

點(diǎn)擊上傳服務(wù)器的按鈕時(shí)調(diào)用這個(gè)函數(shù),也就是說不走upload的鉤子,不調(diào)用他的方法自己搞
    submitUpload () {
      let { uploadFiles } = this.$refs.upload
      let form = new FormData()
      let status = true
      // 在這里對(duì)每一張圖片進(jìn)行大小的校驗(yàn),如果不符合則提示,所有不符合的都提示,校驗(yàn)完成后只要有不符合條件的就不執(zhí)行下面的操作
      uploadFiles.forEach(item => {
        const size = item.raw.size / 1024 <= 500
        if (!size) {
          this.$message.error(`${item.raw.name}大小超過500KB`)
          status = false
          return
        }
        form.append("image[]", item.raw)
      })
      if (!status) {
        return
      }
      // 符合條件后再將這個(gè)FormData對(duì)象傳遞給后端
      //調(diào)取接口上傳form參數(shù)
     
  }

方法二
使用內(nèi)部的回調(diào)去獲取對(duì)應(yīng)的


  選取文件
  上傳到服務(wù)器
  
只能上傳jpg、png、gif 格式,大小不超過500KB的圖片

js

beforeImageUpload (file) { // 上傳文件前的鉤子對(duì)文件進(jìn)行校驗(yàn)
    const size = file.size / 1024 < 500
    if (!size) {
      this.$message.error("上傳圖片大小不能超過 500KB!")
    }
    return size
}

上傳前鉤子返回false之后給文件就不會(huì)再往下執(zhí)行下面的鉤子了
因此在http-request的鉤子就不會(huì)被執(zhí)行,在該鉤子中獲取到的都是通過校驗(yàn)的file文件的信息

ImageRequest (file) {
    this.formData.append("image[]", file.file)
}

此時(shí)在這個(gè)formData 中的數(shù)據(jù)就是通過校驗(yàn)的數(shù)據(jù)

submitUpload () {
    this.formData = new FormData()
    // 手動(dòng)觸發(fā)上傳
    this.$refs.upload.submit()
    // 此時(shí)所有的鉤子已經(jīng)執(zhí)行完了formData 中存的是通過校驗(yàn)的數(shù)據(jù)
    // 此時(shí)在調(diào)用接口上傳該數(shù)據(jù)
}

該方法在使用時(shí)不符合條件的文件會(huì)自動(dòng)刪除只留下符合條件的
可能是before-upload這個(gè)鉤子的原因不符合之后他會(huì)去調(diào)用刪除的鉤子
因此使用方法一比這個(gè)要好很多
該方法節(jié)省了我們自己寫樣式以及預(yù)覽,組件都幫你干了,你只要寫邏輯就好啦

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/54205.html

相關(guān)文章

  • element-ui 使用upload文件上傳請(qǐng)求一次接口

    摘要:方法一不使用組件內(nèi)部的鉤子選取文件上傳到服務(wù)器只能上傳格式,大小不超過的圖片點(diǎn)擊上傳服務(wù)器的按鈕時(shí)調(diào)用這個(gè)函數(shù),也就是說不走的鉤子,不調(diào)用他的方法自己搞在這里對(duì)每一張圖片進(jìn)行大小的校驗(yàn),如果不符合則提示,所有不符合的都提示 方法一不使用組件內(nèi)部的鉤子 選取文件 上傳到服務(wù)器 只能上傳jpg、png、gif 格式,大小不超過500KB的圖片 js 點(diǎn)擊上傳服務(wù)器的按鈕時(shí)調(diào)...

    tomlingtm 評(píng)論0 收藏0
  • Element-ui實(shí)現(xiàn)合并上傳一次請(qǐng)求張圖片)

    摘要:實(shí)現(xiàn)多圖上傳主要用到以下兩個(gè)屬性是自帶多圖上傳的,但是細(xì)心的朋友可能發(fā)現(xiàn)默認(rèn)多圖的實(shí)現(xiàn)可能和我們預(yù)期有些出入,有截圖可以看出,實(shí)質(zhì)是進(jìn)行多次請(qǐng)求在上傳事件觸發(fā)后,多圖上傳的默認(rèn)實(shí)現(xiàn)調(diào)用了三次請(qǐng)求。 前言 工作中碰到需要多圖上傳,在使用element-ui解決過程中碰到一些問題,在這里分享給大家。 環(huán)境: Springboot+Vue+Element-ui 正文 這次上傳使用的是Elem...

    loostudy 評(píng)論0 收藏0
  • element-ui+vue-cli3.0:el-upload

    摘要:最近項(xiàng)目中涉及很多文件上傳的地方,然后文件上傳又有很多限制。比如文件大小限制,文件個(gè)數(shù)限制,文件類型限制,文件上傳后的列表樣式自定義,包括上傳進(jìn)度條等問題。下面是我對(duì)的上傳組件的一些改造,點(diǎn)擊查看源碼。 最近項(xiàng)目中涉及很多文件上傳的地方,然后文件上傳又有很多限制。比如文件大小限制,文件個(gè)數(shù)限制,文件類型限制,文件上傳后的列表樣式自定義,包括上傳進(jìn)度條等問題。下面是我對(duì)element-u...

    yy13818512006 評(píng)論0 收藏0
  • element-ui上傳下載excel(超詳細(xì)der)

    摘要:上傳組件點(diǎn)擊跳轉(zhuǎn)到該組件官方文檔用到的組件參數(shù)參數(shù)說明類型可選默認(rèn)值必選參數(shù),上傳的地址上傳的文件列表接受上傳的文件類型覆蓋默認(rèn)的上傳行為最大允許上傳個(gè)數(shù)文件超出個(gè)數(shù)限制時(shí)的鉤子 1. 上傳 EXCEL Upload組件 點(diǎn)擊跳轉(zhuǎn)到該組件官方文檔 用到的upload組件參數(shù) 參數(shù) 說明 類型 可選 默認(rèn)值 action 必選參數(shù),上傳的地址 string --- --...

    Jeffrrey 評(píng)論0 收藏0
  • 手摸手,帶你用vue擼后臺(tái) 系列三(實(shí)戰(zhàn)篇)

    摘要:社區(qū)的認(rèn)可目前已經(jīng)是相關(guān)最多的開源項(xiàng)目了,體現(xiàn)出了社區(qū)對(duì)其的認(rèn)可。監(jiān)聽事件手動(dòng)維護(hù)列表這樣我們就簡(jiǎn)單的完成了拖拽排序。 完整項(xiàng)目地址:vue-element-admin 系類文章一:手摸手,帶你用vue擼后臺(tái) 系列一(基礎(chǔ)篇)系類文章二:手摸手,帶你用vue擼后臺(tái) 系列二(登錄權(quán)限篇)系類文章三:手摸手,帶你用vue擼后臺(tái) 系列三(實(shí)戰(zhàn)篇)系類文章四:手摸手,帶你用vue擼后臺(tái) 系列...

    Channe 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<