前言

忽然来了需要,要求前端解析出上传文件中的数据,回显到页面上。以前始终是借助后端的帮忙,查了下材料发现前端有插件能够实现,备忘下~

1、可解析文件

2、反对框架

3、安装包

npm install xlsx

4、相干代码

1)HTML局部

<div >    {{ upload_file || "导入" }}    <input type="file" accept=".xls,.xlsx" class="upload_file" @change="readExcel($event)"/></div>

2)data 局部

import XLSX from "xlsx";//须要引入包data () {    return {      upload_file:'',      data:[],    }},

3)办法实现局部

    readExcel(e) {      // 读取表格文件      let that = this;      const files = e.target.files;      if (files.length <= 0) {        return false;      } else if (!/\.(xls|xlsx)$/.test(files[0].name.toLowerCase())) {        this.$message({          message: "上传格局不正确,请上传xls或者xlsx格局",          type: "warning"        });        return false;      } else {        // 更新获取文件名        that.upload_file = files[0].name;      }      const fileReader = new FileReader();      fileReader.onload = ev => {        try {          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表格内容          that.lists = [];          console.log('ws',ws);          // 从解析进去的数据中提取相应的数据          ws.forEach(item => {            that.data.push({              value_id: 0,              value_show_name: item.show_name,              value_name: item.name,              value_color: item.color,              is_deleted: '0'            });          });          that.visibleUp=false;          // 给后端发申请          // this.submit_form();        } catch (e) {          return false;        }      };      fileReader.readAsBinaryString(files[0]);    }

参考链接

1、npmjs -xlsx 介绍
2、参考demo