vue项目中导入excel表格 vue技术交流群(864583465)

vue项目中导入excel表格 vue技术交流群(864583465)
1、安装xlsx插件

cnpm install xlsx --save

2、页面代码

<template>
  <div class="hello">
    <input type="file" ref="upload" accept=".xls,.xlsx" class="outputlist_upload"  @change="fileUploaded">
    <br> <br>
    <el-button @click="uploadExcel()">上传Excel</el-button>
  </div>
</template>

<script>
  import XLSX from 'xlsx'
export default {
  data () {
    return {
      file: null
    }
  },
  methods:{
    uploadExcel(){
      const fileReader = new FileReader();
      fileReader.readAsBinaryString(this.file);
      fileReader.onload = ev => {
        const data = ev.target.result;
        const workbook = XLSX.read(data, {
          type: 'binary'
        });
        const wsname = workbook.SheetNames[0];//取第一张表
        const ws = XLSX.utils.sheet_to_json(workbook.Sheets[wsname]);//生成json表格内容
        console.log(ws) // 读取到的excel表格数据

        //执行自己的业务逻辑

      }
    },
    fileUploaded(event){
      console.log(event.currentTarget.files)
      let fileName = event.currentTarget.files[0].name
      let fileType = fileName.slice(fileName.indexOf('.xls'))
      if(fileType!='.xlsx'&&fileType!='.xls'){
        this.$message.error('请上传excel文件');
      } else {
        this.file = event.currentTarget.files[0];
      }
    },
  },

}
</script>

<style lang="scss">
  .hello{
    box-sizing: border-box;
    padding: 50px;
  }
</style>

3、显示页面
在这里插入图片描述
4、说明
(1)若要读取多个Sheet的excel表格,需要先遍历workbook对象中的SheetNames,SheetNames是一个包含Sheet名称的数组,再循环读取相应的内容即可,主要代码如下:


   for (let sheetName of workbook.SheetNames) {
          let ws = XLSX.utils.sheet_to_json(workbook.Sheets[sheetName]);//生成json表格内容
          console.log(ws) // Sheet名成为sheetName对应的excel数据
        } 
        

(2)步骤3中显示的上传按钮样式可自定义

PS:欢迎加入vue技术交流群(864583465)进行更多问题的探讨,你的问题将是我们大家共同进步的关键

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值