vue项目-xlsx插件的使用-上传excel-读取excel数据

2,930 阅读1分钟

本项目需要上传一个excel表格,并把表格里面的数据给拿出来,传递给后端。

本项目用到了xlsx插件

一: 首先 安装一下xlsx插件 npm install xlsx --save

下面来看一下具体操作:

思路:先创建一个组件,封装好上传插件,以便于在多个地方调用。

组件名字xlsx.vue

<template>
  <div>
    <input
      class="input-file"
      type="file"
      accept=".csv, application/vnd.openxmlformats-officedocument.spreadsheetml.sheet, application/vnd.ms-excel"
      @change="exportData"
    >
    <button @click="btnClick">上传表格</button>
  </div>
</template>

<script>
import XLSX from 'xlsx';//引入插件

export default {
  name: 'InputExcel',
  props: {
    accept: {
      type: String,
      default: '选择excel文件'
    }
  },
  methods: {
    btnClick() {
      document.querySelector('.input-file').click();
    },
    exportData(event) {
      if (!event.currentTarget.files.length) {
        return;
      }
      const that = this;
      // 拿取文件对象
      var f = event.currentTarget.files[0];
      // 用FileReader来读取
      var reader = new FileReader();
      // 重写FileReader上的readAsBinaryString方法
      FileReader.prototype.readAsBinaryString = function(f) {
        var binary = '';
        var wb; // 读取完成的数据
        var outdata; // 你需要的数据
        var reader = new FileReader();
        reader.onload = function(e) {
          // 读取成Uint8Array,再转换为Unicode编码(Unicode占两个字节)
          var bytes = new Uint8Array(reader.result);
          var length = bytes.byteLength;
          for (var i = 0; i < length; i++) {
            binary += String.fromCharCode(bytes[i]);
          }
          // 接下来就是xlsx了,具体可看api
          wb = XLSX.read(binary, {
            type: 'binary'
          });
          outdata = XLSX.utils.sheet_to_json(wb.Sheets[wb.SheetNames[0]]);
          // 自定义方法向父组件传递数据
          that.$emit('getResult', outdata);
        };
        reader.readAsArrayBuffer(f);
      };
      reader.readAsBinaryString(f);
    }
  }
};
</script>

<style scoped>
.input-file {
  display: none;
}
</style>

然后,就可以在页面中用到上传的组件了,下面看一下具体的用法:

<template>
  <div>
      <xlsx @getResult="getMyExcelData">导入参数</xlsx>
  </div>
</template>
<script>
import xlsx from '@/components/xlsx/xlsx';
export default {
  components: {
    xlsx
  },
  methods:{
      getMyExcelData(data) {
      // 上传表格
        console.log(data);
      }
   }
</script>