首頁 > 軟體

vue實現檔案上傳

2022-04-10 19:00:02

本文範例為大家分享了vue實現檔案上傳的具體程式碼,供大家參考,具體內容如下

記錄問題,方便回顧

1、使用elementUI的 el-upload外掛進行上傳。 2、使用input。

1、使用elementUI的 el-upload外掛進行上傳。

html:

<el-upload
    ref="avatar-uploader"
    class="avatar-uploader"
    :show-file-list="false"
    :auto-upload="false"
    action
    :on-change="handleChange"
   >
   <img v-if="AddSubmenuData.imageUrl" :src="AddSubmenuData.imageUrl" class="avatar">
   <i v-else class="el-icon-plus avatar-uploader-icon"></i>
</el-upload>

js:

data() {
      return {
        AddSubmenuData:{
          id:"",
          pid:"",
          funType:1,
          name:"",
          sort:"",
          SystemCoding:"",
          remarks:"",
          imageUrl: ''
        },
      };
  },
  methods: {
      // 獲取圖片資訊並轉成base64
      handleChange(file, fileList){
       let reader = new FileReader();
        let fileResult = "";
        reader.readAsDataURL(file.raw);
        reader.onload = function() {
          fileResult = reader.result;
        };
        reader.onloadend = function() {
           this.AddSubmenuData.imageUrl = fileResult
        };
      }
  }

css:

 /deep/  .avatar-uploader .el-upload {
      border: 1px dashed #d9d9d9;
      border-radius: 6px;
      cursor: pointer;
      position: relative;
      overflow: hidden;
      margin-left: 80px;
      margin-bottom: 22px;
    }
    .avatar-uploader .el-upload:hover {
      border-color: #409EFF;
    }
    .avatar-uploader-icon {
      font-size: 28px;
      color: #8c939d;
      width: 178px;
      height: 178px;
      line-height: 178px;
      text-align: center;

    }
    .avatar {
      width: 178px;
      height: 178px;
      display: block;
    }

效果圖:

2、使用input進行上傳。

1)、html

首先input的type屬性要改成file,如果需求是點選按鈕在上傳檔案。可以給input加一個ref=“fileInput”,然後通過點選按鈕呼叫input的事件:@click="$refs.fileInput.click()".

<div class="el-button--primary el-button" @click="$refs.fileInput.click()">
   <input type="file" ref="fileInput" accept="*" @change="getFile" style="display: none">
   <img src="../../assets/Infrastructure/xz.png" />新增
</div>

2)、js

獲取檔案後就可以進行資料處理並呼叫介面。因為有些時候,上傳檔案有些是重複的,再次呼叫方法就是失效,所以,可以在每次上傳完之後清除之前上傳的檔案,這樣即使檔案相同,也可以重複呼叫方法。this.$refs.fileInput.value=’’

// 獲取檔案資料
  getFile(event) {
//這就是你上傳的檔案
       event.target.files[0]
       
       let formFile = new FormData();
        formFile.append("file", event.target.files[0]);
        formFile.append("apply_info_id", this.RndNum(12));
        formFile.append("file_type", '');
        //呼叫介面
        file_upload(formFile).then(res => {
          this.addInformation.addPoupTableData.data.push({name:res.data.name,id:res.data.id,size:(event.target.files[0].size/1024).toFixed(0) + "kb",path:res.data.path})
          //呼叫介面後清除檔案
          this.$refs.fileInput.value=''
        })
 },

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援it145.com。


IT145.com E-mail:sddin#qq.com