• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

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

vue 搞代码 4年前 (2022-01-08) 23次浏览 已收录 0个评论

这篇文章主要介绍了vue excel上传预览和table内容下载到excel文件中,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下

excel上传预览

这里会用到

 npm i element-ui npm i xlsx

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

 <div> 选择文件 </div><div>上传到服务器</div> 

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  { let obj = {}; obj.name = v.姓名; obj.department = v.部门; arr.push(obj); }); // 放入到element的table中显示出来 that.listTable = arr; }; reader.readAsArrayBuffer(f); }; if (rABS) { reader<i>本文来源gaodai$ma#com搞$$代**码)网@</i>.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上传文件模板

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文件中的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:vue excel上传预览和table内容下载到excel文件中

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址