您现在的位置是:首页 > 技术教程 正文

vue3导入excel并解析excel数据渲染到表格中,纯前端实现。

admin 阅读: 2024-03-28
后台-插件-广告管理-内容页头部广告(手机)

需求

用户将已有的excel上传到系统,并将excel数据同步到页面的表格中进行二次编辑,由于excel数据不是最终数据,只是批量的一个初始模板,后端不需要存储,所以该功能由前端独立完成。

吐槽

系统中文件上传下载预览三部曲走了一遍,万万没想到还要自己实现同步数据。

实际

反手各种资料开始查阅,终于找到了可以完美实现该需求的方法,来记录下我的实现方案。希望对有需要的小伙伴有帮助。

注意以下为正文(重要内容),好好阅读,不要漏掉重要知识点奥~ 


涉及到的主要知识点

  • 插件xlsx
  • elementUI  plus中的Upload 上传组件
  • 动态设置 ref

展开说说:

1、插件xlsx

  1. // 在项目根路径 安装xlsx
  2. npm install -S xlsx
  3. // 在需要使用的页面引入xlsx
  4. import * as xlsx from 'xlsx'

2、upload上传组件

上传组件的自动上传方法,传参方法,详细可翻阅elementUI plus官网

3、动态设置ref

涉及到动态设置ref的原因:

一是由于upload组件在设置了 :limit="1",在上传第一个文件之后,浏览器会保存着我们已经上传的文件,导致我们继续上传文件的时候,页面没有反应;解决该问题需要在on-success钩子函数中通过ref来清除已经上传的文件。

  1. <script setup>
  2. import { ref } from 'vue'
  3. const importExcelRef = ref(null)
  4. const importSuccess = ()=>{
  5. importExcelRef.value.clearFiles();
  6. }
  7. script>

二是因为表单中存在多个表格需要导入excel作为基础数据进行编辑,且表格数量不固定,是根据后端数据渲染的,所以在清空上传文件的时候,需要处理未知的多个,所以需要动态设置ref。

  1. <script>
  2. import { ref } from 'vue'
  3. const uploadRefMap = ref({});
  4. // 动态设置upload Ref
  5. const handleSetUploadRefMap = (el,rowIndex,compIndex) => {
  6. if (el) {
  7. uploadRefMap.value[`Upload_Ref_${rowIndex}_${compIndex}`] = el
  8. }
  9. }
  10. script>

需求实现代码

  1. <script setup name="mainContent">
  2. import * as xlsx from 'xlsx'
  3. import {ElMessage} from 'element-plus'
  4. import { ref } from 'vue'
  5. const uploadRefMap = ref({});
  6. const excelList = ref([])
  7. // 动态设置upload Ref
  8. const handleSetUploadRefMap = (el) => {
  9. if (el) {
  10. uploadRefMap.value[`Upload_Ref`] = el
  11. }
  12. }
  13. // 文件上传自定义
  14. const httpExcelRequest = async (op) => {
  15. // 获取除文件之外的参数,具体根据实际业务需求来
  16. console.log(op.data)
  17. // 获取上传的excel 并解析数据
  18. let file = op.file
  19. let dataBinary = await readFile(file);
  20. let workBook = xlsx.read(dataBinary, { type: "binary", cellDates: true })
  21. let workSheet = workBook.Sheets[workBook.SheetNames[0]]
  22. const excelData = xlsx.utils.sheet_to_json(workSheet,{ header: 1 })
  23. excelList.value = excelData
  24. console.log(excelData)
  25. if(uploadRefMap.value[`Upload_Ref`]){
  26. uploadRefMap.value[`Upload_Ref`].clearFiles();
  27. }
  28. }
  29. const readFile = (file) => {
  30. return new Promise((resolve) => {
  31. let reader = new FileReader()
  32. reader.readAsBinaryString(file)
  33. reader.onload = (ev) => {
  34. resolve(ev.target?.result)
  35. }
  36. })
  37. }
  38. script>
  39. <style lang="scss" scoped>
  40. .uploadExcelContent{
  41. display: flex;
  42. flex-direction: row;
  43. }
  44. .excel-content{
  45. display: flex;
  46. flex-direction: row;
  47. align-items: center;
  48. .comp{
  49. width: 200px;
  50. font-size: 12px;
  51. }
  52. }
  53. style>

由于业务需求不同,对表格数据的详细处理逻辑,就不在这里显示了,可根据自己的数据结构进行赋值操作,运行demo后可以直接在控制台查看拿到的excel数据。

今天就到这里了,会继续加油的,是亮晶晶的芋头哟~

标签:
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

在线投稿:投稿 站长QQ:1888636

后台-插件-广告管理-内容页尾部广告(手机)
关注我们

扫一扫关注我们,了解最新精彩内容

搜索
排行榜