vue下載excel模板並提交數據

  上一篇說了一下後端使用easyexcel處理excel然後進行入庫的,這一篇我們就使用vue調用後端的接口吧!這裏組件的話使用element的上傳組件,下面有兩種,我就用手動上傳這種方式:

 

  最後的畫面如圖所示:

 

 1.templage代碼:

<template>
  <div class='app-container'>
    <el-form label-width="120px">
      <el-form-item label="信息描述">
        <el-tag type="info">excel模版說明:課程分類模板,用戶必須按照這個模板進行填寫</el-tag>
        <br>
        <el-tag>
          <i class="el-icon-download" />
          <!-- 這裏的話可以把這個模板放到阿里的OSS中 -->
          <a :href="downloadUrl">點擊下載模版</a>
        </el-tag>
      </el-form-item>

      <el-form-item label="選擇Excel">
        <el-upload ref="upload"
                   :auto-upload="false"
                   :on-success="fileUploadSuccess"
                   :on-error="fileUploadError"
                   :disabled="importBtnDisabled"
                   :limit="1"
                   :action="formSubmitFileUrl"
                   name="file"
                   accept="application/vnd.ms-excel">
          <el-button slot="trigger"
                     size="small"
                     type="primary">選擇上傳文件</el-button>
          <el-button :loading="loading"
                     style="margin-left: 10px;"
                     size="small"
                     type="success"
                     @click="submitUpload">上傳到服務器</el-button>
        </el-upload>
      </el-form-item>
    </el-form>
  </div>
</template>

 

 2.script代碼:

export default {
  data () {
    // 這裏存放數據
    return {
      importBtnDisabled: false, // 按鈕是否禁用,
      loading: false,
      downloadUrl: "/static/test.xlsx",//excel模板文件,可以放到OSS中,也可以就放到vue項目中的static目錄中,提供給用戶下載
      formSubmitFileUrl: process.env.BASE_API + "/edu/subject/addSubject"//調用後端解析excel的接口
    }
  },
  methods: {
    //上傳到服務器,這裏是vue中提交表單的寫法this.$refs.upload.submit()
    submitUpload () {
      this.importBtnDisabled = true
      this.loading = true
      this.$refs.upload.submit()
    },
    //上傳成功
    fileUploadSuccess () {
      this.loading = false
      this.$message({
        type: 'success',
        message: '添加課程分類成功'
      })
      //導入成功之後跳轉到課程列表界面
      // this.$router.push({ path: '/edu/subject/list' })
    },
    //上傳失敗
    fileUploadError () {
      this.loading = false
      this.$message({
        type: 'error',
        message: '導入文件失敗'
      })
    }
  }

}

 

  

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章