利用SheetJS在前端解析Excel读取数据并赋值给组件

‌**xlsx.full.min.js** ‌是一个由SheetJS出品的JavaScript工具包,专门设计用于在前端环境中读取和导出Excel文件。它支持多种格式,包括xlsxlsxods等,极大地简化了在Web应用中处理Excel数据的过程‌。

使用xlsx.full.min.js的基本步骤如下:

  1. 引入库文件:在HTML文件中引入xlsx.full.min.js 库。
  2. 读取Excel文件:通过HTML的<input>元素选择文件后,使用JavaScript监听文件变化时间,获取文件内容。
  3. 处理数据:将读取到的数据转化成JSON格式或其它所需格式进行处理。

下面演示如何在前端页面上解析excel数据并赋值给组件

  1. 下载 xlsx.full.min.js 第三方库,并在页面引入

    <#-- 前端解析 excel 插件-->

    <script type="text/javascript" src="/dist/xlsx.full.min.js"></script>
  2. 创建一个文件类型的输入框<input type="file">, 供用户上传文件。onchange是对该控件进行监听,有文件上传时,调用自定义 inDateByExcel() 方法。

    <label>一键导入</label>
  3. 编写自定义方法 inDateByExcel(),处理数据

    // 一键导入
    window.inDateByExcel = function (e) {
    var file = e.target.files[0]; // 得到上传的文件
    var type = file.name.split('.'); // 得到一个数组存放文件名和文件后缀
    // 判断上传的文件是否是excel 类型,不是则提示
    if (type[type.length - 1] !== 'xlsx' && type[type.length - 1] !== 'xls') {
    layer.alert('只能导入excle文件', { title: '上传失败', icon: 5, time: 3000);
    } else {
    var reader = new FileReader();
    reader.readAsArrayBuffer(file);

    复制代码
         reader.onload = function (e) {
            var data = new Uint8Array(reader.result);
            var workbook = XLSX.read(data, {type: 'array'});
            // 假设我们只读取第一个工作表
            var firstSheetName = workbook.SheetNames[0];
            var worksheet = workbook.Sheets[firstSheetName];
            // 将工作表转换为JSON
            var json = XLSX.utils.sheet_to_json(worksheet);
            $.each(json, function (i, v) {
              //     console.log(v)
             // 给单选按钮赋值
             $('input[type="radio"][name="payType"][value="'+ v.付款方式 +'"]').prop('checked', true);  // 付款方式
             $('#username').val(v.姓名);  // 姓名
             $('#phone').val(v.电话);  // 电话
             $('#address').val(v.地址);  // 地址
             // 如果 excel 里的字段没有数据,在浏览器打印出来是找不到该字段的,
             if (v.产品编码 != 'undefined') {        // 产品编码非必填项
                $('#productCode').val(v.产品编码);  // 产品编码
              }
             form.render();  // layui的下拉框、单选按钮类型改变值后需要重新渲染,这里是所有类型都重新渲染
             });
          }
      }
    
    }

经过上述步骤就,就实现了在前端页面解析excel数据。

相关推荐
asdzx672 分钟前
使用 C# 添加或读取 Excel 公式:完整指南
开发语言·c#·excel
幽络源小助理4 分钟前
在线图片处理工具源码, 多功能编辑格式转换HTML单文件版
前端·html
humcomm6 分钟前
AI编程时代前端架构师的机遇和挑战
前端·架构·ai编程
开开心心就好10 分钟前
免费开源的网课教学屏幕画板工具
windows·eureka·计算机外设·word·excel·etcd·csdn开发云
adminwolf15 分钟前
自研企业微信SCRM系统源码独立部署(Golang+Vue.js)
前端·vue.js·企业微信
fengyehongWorld16 分钟前
EXCEL XLOOKUP函数
excel
小短腿的代码世界16 分钟前
QwtPolar 与实时示波器级渲染优化:雷达图到示波器曲线的极限性能调优
前端·qt·架构·交互
机器视觉知识推荐、就业指导33 分钟前
npm 安装/运行报错及解决方案
前端·npm·node.js
摇滚侠34 分钟前
12 移动端 WEB 前端 WEB 开发 HTML5 + CSS3 + 移动 WEB
前端·css3·html5
ez52fF0k836 分钟前
.NET11云原生CI/CD在云原生应用持续集成与交付安全加固
前端·c#·交互