vue-simple-uploader組件的使用感受

題記:
(可直接跳過)
我剛實(shí)習(xí)的時(shí)候,就接手了一個(gè)任務(wù):重寫項(xiàng)目中前端文件上傳功能,因?yàn)樾枰С治募A上傳這個(gè)功能點(diǎn),考慮之后準(zhǔn)備用插件,最后選擇了vue-simple-uploader鳞青。但沒想到這個(gè)插件從我實(shí)習(xí)開始陪伴到我實(shí)習(xí)結(jié)束,剛開始時(shí)這個(gè)插件完成了大部分的需求为朋,但是文件夾上傳時(shí)臂拓,上傳速率和預(yù)計(jì)剩余時(shí)間一直不正確,我改了很久也沒成功习寸,后來因?yàn)槠渌拈_發(fā)任務(wù)就一直放在角落里吃灰胶惰。實(shí)習(xí)快結(jié)束時(shí),恰好產(chǎn)品發(fā)布融涣,清一下bug童番,又撿了回來,重新根據(jù)需求優(yōu)化了這個(gè)插件威鹿,但是還是沒成功剃斧,無奈只好隱藏掉上傳速率和剩余時(shí)間,在實(shí)習(xí)結(jié)束之前忽你,成為了我的一個(gè)遺憾幼东。

學(xué)習(xí)教程:
關(guān)于這個(gè)插件,可以直接在GitHub上看官方文檔和源碼科雳,源碼很精煉根蟹。

官方git鏈接:https://github.com/simple-uploader/vue-uploader
寫的很好的使用教程:
https://www.cnblogs.com/xiahj/p/vue-simple-uploader.html
https://www.helloweba.net/javascript/632.html

粗略的項(xiàng)目實(shí)現(xiàn)(上面給了兩個(gè)寫的很好的使用教程,可以去圍觀圍觀):

  1. 安裝插件
npm install vue-simple-uploader --save
  1. main.js中初始化
import uploader from 'vue-simple-uploader'
Vue.use(uploader)
  1. 具體vue文件中:template
        <uploader
          :options="options"
          :file-status-text="statusText"
          :auto-start="false"
          class="uploader-example"
          ref="uploader"
          @file-added="onFileAdded"
          @file-success="onFileSuccess"
          @file-error="onFileError"
          @file-removed="fileRemoved"
        >
          <uploader-unsupport></uploader-unsupport>
          <uploader-drop>
            <uploader-btn :attrs="attrs" style="background-color: #67C13B"><i class="el-icon-upload" style="margin-right: 5px"></i>上傳文件</uploader-btn>
            <uploader-btn :directory="true" style="background-color: #79BBFF"><i class="el-icon-folder-add" style="margin-right: 5px"></i>上傳文件夾</uploader-btn>
          </uploader-drop>
          <uploader-list ></uploader-list>
        </uploader>
        <div slot="footer" class="dialog-footer">
          <span class="filetotal">共計(jì): {{this.file_total}}</span>
          <el-button type="danger" plain @click="errorDialog=true" v-show="controllerErrorFileDialog">錯誤信息</el-button>
          <el-button @click="cancelUpload">取消上傳</el-button>
          <el-button type="primary" @click="submitUpload">開始上傳</el-button>
        </div>
  1. data中數(shù)據(jù)定義
        options: {
          target: url,
          maxChunkRetries: 2,
          testChunks: false,
          fileParameterName: 'contents',
          chunkSize: 1024 * 1024 * 1024,
          simultaneousUploads: 3,
          query: {
              type: '',
              create_time: ''
            },
          headers: {
            'Authorization': token
          },
        },
        statusText: {
          success: '上傳成功',
          error: '上傳失敗',
          uploading: '上傳中',
          paused: '暫停中',
          waiting: '等待中'
        },
        attrs: {
          accept: [],
        },
        file_total: 0, //本次文件上傳的總數(shù)
        errorfilelist: [], //上傳失敗信息列表
  1. methods
//添加文件到列表還未上傳,每添加一個(gè)文件糟秘,就會調(diào)用一次,在這里過濾并收集文件夾中文件格式不正確信息简逮,同時(shí)把所有文件的狀態(tài)設(shè)為暫停中
      onFileAdded(file) {
        let file_type = file.name.substring(file.name.lastIndexOf(".") + 1);
        const extension = file_type === this.uploadType;
        if (!extension) {
          let obj = {
            rootname: '無',
            name: file.name,
            errorinfo: "文件不是 " + this.uploadType + " 格式",
          };
          let arr=file.relativePath.split("/");
          if(arr.length>1){
            obj['rootname'] =arr[0]
          }
          this.errorfilelist.push(obj);
          file.ignored = true
        }else{
          file.pause();
        }
        this.$nextTick(() => {
          this.file_total=this.$refs['uploader'].files.length
        });
        if(this.errorfilelist.length !== 0){
          this.controllerErrorFileDialog = true
        }
      },

//每個(gè)文件傳輸給后端之后,返回的信息
      onFileSuccess(rootFile, file, response, chunk) {
        let res=JSON.parse(response)
        if(res.code!==10000){
          let obj = {
            rootname: '無',
            name: file.name,
            errorinfo: res.message,
          };
          if(rootFile.isFolder===true){
            obj['rootname'] = rootFile.name
          }
          this.errorfilelist.push(obj);
          this.controllerErrorFileDialog = true
        }
      },
      // 上傳錯誤觸發(fā)尿赚,文件還未傳輸?shù)胶蠖?      onFileError(rootFile, file, response, chunk) {
        let obj = {
          rootname: '無',
          name: file.name,
          errorinfo: "文件上傳失敗",
        };
        if(rootFile.isFolder===true){
          obj['rootname'] = rootFile.name
        }
        this.errorfilelist.push(obj);
        this.controllerErrorFileDialog = true
      },
      // 移除文件
      fileRemoved(file){
        this.$nextTick(() => {
          this.file_total=this.$refs['uploader'].files.length
        });
      },
//點(diǎn)擊開始上傳按鈕
      submitUpload() {
        this.$nextTick(() => {
          for(var i=0;i<this.$refs['uploader'].files.length;i++){
            this.$refs['uploader'].files[i].resume()
          }
        });
      },
      //關(guān)閉錯誤文件提示框口散庶,知道上傳對話框被關(guān)閉時(shí)才會被清空
      closeErrorDialog(){
        this.errorDialog = false;
      },
      // 上傳彈框關(guān)閉
      handelClose(){
        this.clearcache()
        this.thirdDialog = false
      },
      // 清除緩存
      clearcache() {
        this.file_total = 0;
        this.errorfilelist=[]
        this.controllerErrorFileDialog = false
        this.$refs.uploader.uploader.cancel()
        this.getresourceDetail();
      },
      //取消上傳
      cancelUpload() {
        this.thirdDialog = false;
        this.clearcache();
      },
  1. css中樣式
// 文件上傳組件
  .uploader-example {
    width: 90%;
    padding: 15px;
    margin: 0 auto 0;
    font-size: 14px;
    box-shadow: 0 0 10px rgba(0, 0, 0, .4);
  }
  .uploader-example .uploader-btn {
    margin-right: 8px;
    color: #ffffff;
    border: #ffffff;
  }
  /deep/ .uploader-example .uploader-list {
    max-height: 300px;
    overflow: auto;
    overflow-x: hidden;
    overflow-y: auto;
    .uploader-file[status="uploading"]> .uploader-file-info{
      > .uploader-file-status > span> i{
        visibility:hidden;
      }
      > .uploader-file-status > span> em{
        visibility:hidden;
      }
    }
  }

先這樣吧蕉堰,寫的比較粗糙,以后有時(shí)間會review進(jìn)行完善的悲龟。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末屋讶,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子须教,更是在濱河造成了極大的恐慌皿渗,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,194評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件轻腺,死亡現(xiàn)場離奇詭異乐疆,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)约计,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評論 2 385
  • 文/潘曉璐 我一進(jìn)店門诀拭,熙熙樓的掌柜王于貴愁眉苦臉地迎上來迁筛,“玉大人煤蚌,你說我怎么就攤上這事∠肝裕” “怎么了尉桩?”我有些...
    開封第一講書人閱讀 156,780評論 0 346
  • 文/不壞的土叔 我叫張陵,是天一觀的道長贪庙。 經(jīng)常有香客問我蜘犁,道長,這世上最難降的妖魔是什么止邮? 我笑而不...
    開封第一講書人閱讀 56,388評論 1 283
  • 正文 為了忘掉前任这橙,我火速辦了婚禮,結(jié)果婚禮上导披,老公的妹妹穿的比我還像新娘屈扎。我一直安慰自己,他們只是感情好撩匕,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,430評論 5 384
  • 文/花漫 我一把揭開白布鹰晨。 她就那樣靜靜地躺著,像睡著了一般止毕。 火紅的嫁衣襯著肌膚如雪模蜡。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,764評論 1 290
  • 那天扁凛,我揣著相機(jī)與錄音忍疾,去河邊找鬼。 笑死谨朝,一個(gè)胖子當(dāng)著我的面吹牛卤妒,可吹牛的內(nèi)容都是我干的丸边。 我是一名探鬼主播,決...
    沈念sama閱讀 38,907評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼荚孵,長吁一口氣:“原來是場噩夢啊……” “哼妹窖!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起收叶,我...
    開封第一講書人閱讀 37,679評論 0 266
  • 序言:老撾萬榮一對情侶失蹤骄呼,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后判没,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蜓萄,經(jīng)...
    沈念sama閱讀 44,122評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,459評論 2 325
  • 正文 我和宋清朗相戀三年澄峰,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了嫉沽。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,605評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡俏竞,死狀恐怖绸硕,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情魂毁,我是刑警寧澤玻佩,帶...
    沈念sama閱讀 34,270評論 4 329
  • 正文 年R本政府宣布席楚,位于F島的核電站咬崔,受9級特大地震影響烦秩,放射性物質(zhì)發(fā)生泄漏垮斯。R本人自食惡果不足惜只祠,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,867評論 3 312
  • 文/蒙蒙 一兜蠕、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧铆农,春花似錦、人聲如沸墩剖。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至爷绘,卻和暖如春书劝,著一層夾襖步出監(jiān)牢的瞬間进倍,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評論 1 265
  • 我被黑心中介騙來泰國打工猾昆, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留骡苞,地道東北人垂蜗。 一個(gè)月前我還...
    沈念sama閱讀 46,297評論 2 360
  • 正文 我出身青樓贴见,卻偏偏與公主長得像,于是被迫代替她去往敵國和親片部。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,472評論 2 348

推薦閱讀更多精彩內(nèi)容