欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

vue excel上传预览和table内容下载到excel文件中

程序员文章站 2022-07-06 18:33:06
excel上传预览 这里会用到 npm i element-ui npm i xlsx 在vue的template中写上,排版和css看个人需求 &l...

excel上传预览

vue excel上传预览和table内容下载到excel文件中

这里会用到

npm i element-ui
npm i xlsx

在vue的template中写上,排版和css看个人需求

<div> 选择文件
 <input type="file" d="file_input" @change="importf(this)" accept=".csv, application/vnd.openxmlformats-officedocument.spreadsheetml.sheet, application/vnd.ms-excel" />
</div>
<div @click="filebtn">上传到服务器</div>
<el-table class="listtable_ele" :data="listtable" stripe height="250" style="width:100%">
 <el-table-column prop="name" label="员工姓名" width="180" align="center"></el-table-column>
 <el-table-column prop="department" label="职务/部门" align="center"></el-table-column>
</el-table>

vue的js中写上

export default {
 data() {
 return {
  listtable: []
   }
 },
 methods:{
 // 上传预览
   importf(obj) {
    let that= this;
    let inputdom = this.$refs.inputer; // 通过dom取文件数据
    this.file = event.currenttarget.files[0];
    var rabs = false; //是否将文件读取为二进制字符串
    var f = this.file;
    var reader = new filereader();
    //if (!filereader.prototype.readasbinarystring) {
    filereader.prototype.readasbinarystring = function(f) {
     var binary = "";
     var rabs = false; //是否将文件读取为二进制字符串
     var pt = this;
     var wb; //读取完成的数据
     var outdata;
     var reader = new filereader();
     reader.onload = function(e) {
      var bytes = new uint8array(reader.result);
      var length = bytes.bytelength;
      for (var i = 0; i < length; i++) {
       binary += string.fromcharcode(bytes[i]);
      }
      var xlsx = require("xlsx");
      if (rabs) {
       wb = xlsx.read(btoa(fixdata(binary)), {
        //手动转化
        type: "base64"
       });
      } else {
       wb = xlsx.read(binary, {
        type: "binary"
       });
      }
      // outdata就是你想要的东西 excel导入的数据
      outdata = xlsx.utils.sheet_to_json(wb.sheets[wb.sheetnames[0]]);
      // excel 数据再处理
      let arr = [];
      // 这里需要注意名字一定要和excel的内容的文字对上
      outdata.map(v => {
       let obj = {};
       obj.name = v.姓名;
       obj.department = v.部门;
       arr.push(obj);
      });
      // 放入到element的table中显示出来
      that.listtable = arr;
     };
     reader.readasarraybuffer(f);
    };
    if (rabs) {
     reader.readasarraybuffer(f);
    } else {
     reader.readasbinarystring(f);
    }
    // 这里补个时间问题,excel的时间格式是序列号,如果用的上需要转化
    // 需要在这个位置加上调用方法
    // outdata.map(v => {
    //  let obj = {};
    //  obj.time= exceldatetojsdate(v.时间);
    //  arr.push(obj);
    // });
    // 这个方法暂时是目前找的比较好,日期不是很精确,精确不到秒(暂未查出小时和分钟出问题),excel日期序列号装换成时间格式,
    // function exceldatetojsdate(serial) {
    //  let utc_days = math.floor(serial - 25569);
    //  let utc_value = utc_days * 86400;
    //  let date_info = new date(utc_value * 1000);
    //  let fractional_day = serial - math.floor(serial) + 0.0000001;
    //  let total_seconds = math.floor(86400 * fractional_day);
    //  let seconds = total_seconds % 60;
    //  total_seconds -= seconds;
    //  let hours = math.floor(total_seconds / (60 * 60));
    //  let minutes = math.floor(total_seconds / 60) % 60;
    //  let ctime=new date(date_info.getfullyear(), date_info.getmonth(), date_info.getdate(), hours, minutes, seconds);
    // 这是时间拼接,需要什么格式可以自行拼接
    //  return (ctime.getfullyear()+'-'+(ctime.getmonth()+1)+'-'+ctime.getdate());
    // }
   },
   // 上传按钮
   filebtn() {
   //上传这里可以分两种,一种是直接获取input的文件上传给后端,一种是我们已经解析了excel所以只要把listtable数组传给后端
   //两种方法都可行,看自己需求
   }
 }
}

下面是excel上传文件模板

vue excel上传预览和table内容下载到excel文件中

table内容下载到excel文件中

因为方式不一样,需要在安装

npm i file-saver

在vue的script中引入

import xlsx from "xlsx";
import filesaver from "file-saver";

内容导出,写在vue的methods中

downbtn() {
 // 获取table的dom元素
 let vv = xlsx.utils.table_to_book(document.getelementbyid("tableexcel"));
 let vbouts = xlsx.write(vv, {
  booktype: "xlsx",
  booksst: true,
  type: "array"
 });
 try {
  filesaver.saveas(
   // 这是下载的excel文件名 
   new blob([vbouts], { type: "application/octet-stream" }),
   "员工表.xlsx"
  );
 } catch (e) {
  if (typeof console !== "undefined") console.log(e, vbouts);
 }
 return vbouts;
}

总结

以上所述是小编给大家介绍的vue excel上传预览和table内容下载到excel文件中,希望对大家有所帮助