如何实现Excel导入

405 阅读1分钟

一. 安装依赖

xlsx --> excel处理库 excel的导入导出都是依赖于 js-xlsx 来实现的 --> 在此依赖包的基础上封装了便于导出数据的Export2Excel.js文件

二. 创建文件, 放入UploadExcel

在src路径下创建组件--> UploadExcel/index.vue

<template>
  <div>
    <!-- :on-success="handleAvatarSuccess"
      :before-upload="beforeAvatarUpload" -->
    <el-upload
      class="avatar-uploader"
      action="#"
      :show-file-list="false"
      :http-request="upload"
    >
      <img v-if="value" :src="value" class="avatar">
      <i v-else class="el-icon-plus avatar-uploader-icon" />
      <el-progress v-show="isShowProgress" type="circle" :percentage="percentage" :width="178" class="progress" />
    </el-upload>
  </div>
</template>

<script>
// 实例化cos对象
const COS = require('cos-js-sdk-v5')
// 填写自己腾讯云cos中的key和id (密钥)
const cos = new COS({
  SecretId: 'AKID3wZw2sRjlW0D9oCJAk23nH2WjgMkrpXy', // 身份识别ID
  SecretKey: 'B4g15sOdcJkunPkob6KIzPXP0LPBhwua' // 身份秘钥
})
export default {
  name: 'UploadImg',
  props: {
    value: {
      type: String,
      default: ''
    }
  },
  data() {
    return {
      isShowProgress: false,
      percentage: 0
    }
  },
  methods: {
    upload(res) {
      if (res.file) {
        this.isShowProgress = true
        cos.putObject({
          Bucket: 'rlzy-one-1306404223', /* 存储桶 */
          Region: 'ap-beijing', /* 存储桶所在地域,必须字段 */
          Key: res.file.name, /* 文件名 */
          StorageClass: 'STANDARD', // 上传模式, 标准模式
          Body: res.file, // 上传文件对象
          onProgress: (progressData) => {
            console.log(JSON.stringify(progressData))
            this.percentage = progressData.percent * 100
            if (progressData.percent === 1) {
              this.isShowProgress = false
            }
          }
        }, (err, data) => {
          console.log(err || data)
          if (data.statusCode === 200) {
            const urlImg = `https:${data.Location}`
            this.$emit('input', urlImg)
          }
        })
      }
    }
    // handleAvatarSuccess(res, file) {
    //   this.imageUrl = URL.createObjectURL(file.raw)
    // },
    // beforeAvatarUpload(file) {
    //   const isPNG = file.type === 'image/png'
    //   const isLt2M = file.size / 1024 / 1024 < 2
    //   if (!isPNG) {
    //     this.$message.error('上传头像图片只能是 PNG 格式!')
    //   }
    //   if (!isLt2M) {
    //     this.$message.error('上传头像图片大小不能超过 2MB!')
    //   }
    //   return isPNG && isLt2M
    // }
  }
}
</script>

<style>
.avatar-uploader .el-upload {
  border: 1px dashed #d9d9d9;
  border-radius: 6px;
  cursor: pointer;
  position: relative;
  overflow: hidden;
}
.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;
}
.progress {
  position: absolute;
  top: 1px;
  left: 1px
}
</style>

三. 使用该组件,灵活应用该组件上的通信事件

// 伪代码
import uploadExcel from 'xxx/UploadExcel'
// 使用组件
<upload-excel :on-success="handleSuccess" :before-upload="handleUpload" />
  • beforeUpload: 可以在上传之前对数据做一些条件限制,判断 --》 参数就是当前传入的文件
beforeUpload(file) {
 const isLt1M = file.size / 1024 / 1024 < 1

 if (isLt1M) {
   return true
 }

 this.$message({
   message: 'Please do not upload files larger than 1m in size.',
   type: 'warning'
 })
 return false
}
  • onSuccess: 解析成功触发的回调函数,返回表格的表头和内容
handleSuccess({ results, header }) {
  this.tableData = results  // 内容
  this.tableHeader = header  // 表头
}