react中预览excel表格

查了很多资料,很多插件,有很多也用不了,最后试了xlsx这个插件,可以使用。

话不多少了,直接放代码吧:

1.代码实现

javascript 复制代码
fetch(API).then((res: any) => {
        res?.blob().then((r: any) => {
          const reader = new FileReader();
          //通过readAsArrayBuffer将blob转换为ArrayBuffer对
          reader.readAsArrayBuffer(r) // 这里的res.data是blob文件流
          reader.onload = (event: any) => {
            // 读取ArrayBuffer数据变成Uint8Array
            let data = new Uint8Array(event.target.result);
            // 这里的data里面的类型和后面的type类型要对应
            let workbook = XLSX.read(data, { type: "array" });
            set_work_book(workbook);
            let sheetNames = workbook.SheetNames; // 工作表名称
            set_sheet_names(sheetNames);
            set_select_sheet(sheetNames[0]);
            let worksheet = workbook.Sheets[sheetNames[0]];
            // var excelData = XLSX.utils.sheet_to_json(worksheet); //JSON
            let html = XLSX.utils.sheet_to_html(worksheet);
            document.getElementsByClassName('xlsxClass')[0].innerHTML = html
          };
        })
      })

简单说一下,我的excel文件是后台返回的,拿到res之后,先转为blob格式,然后经过一系列的转义,最终拿到Unit8Array格式数据,通过插件XLSX的read方法,读出excel的数据,worksheet就是excel文件中具体每一行的数据:

workbook.Sheets[sheetNames[0]]是用来访问工作簿中名为sheetNames[0](指的第一个)的工作表,XLSX.utils.sheet_to_html(worksheet)这个函数则是将工作表(worksheet)转换成HTML表格的形式,生成HTML代码,然后使用innerHTML将数据写到页面上即可。

2,优化

这种方法预览的数据没有边框,我们自己写一下样式即可:

css 复制代码
.xlsxClass {
      table {
        border: 1px solid #c9c9c9c9;
        td {
          border-left: 1px solid #c9c9c9c9;
          border-bottom: 1px solid #c9c9c9c9;
          padding: 10px;
          min-width: 120px;
        }
      }
    }

然后还有一个问题,如果是多个表的话,需要将workbook存下来,首先把拿到的工作簿列表进行页面显示,然后点击的时候切换时再次执行:获取当前点击的工作簿以及转为html并显示的操作,替换掉名字就行了。

相关推荐
纸上的彩虹14 分钟前
半年一百个页面,重构系统也重构了我对前端工作的理解
前端·程序员·架构
be or not to be41 分钟前
深入理解 CSS 浮动布局(float)
前端·css
LYFlied1 小时前
【每日算法】LeetCode 1143. 最长公共子序列
前端·算法·leetcode·职场和发展·动态规划
老华带你飞1 小时前
农产品销售管理|基于java + vue农产品销售管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
小徐_23331 小时前
2025 前端开源三年,npm 发包卡我半天
前端·npm·github
GIS之路2 小时前
GIS 数据转换:使用 GDAL 将 Shp 转换为 GeoJSON 数据
前端
JIngJaneIL2 小时前
基于springboot + vue房屋租赁管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
天天扭码2 小时前
以浏览器多进程的角度解构页面渲染的整个流程
前端·面试·浏览器
你们瞎搞3 小时前
Cesium加载20GB航测影像.tif
前端·cesium·gdal·地图切片
milanleon3 小时前
使用Spring Security进行登录认证
java·前端·spring