利用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数据。

相关推荐
江湖有缘1 分钟前
Docker部署music-tag-web音乐标签编辑器
前端·docker·编辑器
恋猫de小郭1 小时前
Flutter Zero 是什么?它的出现有什么意义?为什么你需要了解下?
android·前端·flutter
崔庆才丨静觅8 小时前
hCaptcha 验证码图像识别 API 对接教程
前端
passerby60618 小时前
完成前端时间处理的另一块版图
前端·github·web components
掘了9 小时前
「2025 年终总结」在所有失去的人中,我最怀念我自己
前端·后端·年终总结
崔庆才丨静觅9 小时前
实用免费的 Short URL 短链接 API 对接说明
前端
崔庆才丨静觅9 小时前
5分钟快速搭建 AI 平台并用它赚钱!
前端
崔庆才丨静觅9 小时前
比官方便宜一半以上!Midjourney API 申请及使用
前端
Moment9 小时前
富文本编辑器在 AI 时代为什么这么受欢迎
前端·javascript·后端
崔庆才丨静觅10 小时前
刷屏全网的“nano-banana”API接入指南!0.1元/张量产高清创意图,开发者必藏
前端