salesforce lightning零基础学习(十七) 实现上传 Excel解析其内容

时间:2022-10-06 13:01:51

本篇参考:

https://developer.mozilla.org/zh-CN/docs/Web/API/FileReader

https://github.com/SheetJS/sheetjs

salesforce零基础学习(八十九)使用 input type=file 以及RemoteAction方式上传附件

我们都知道salesforce支持对csv的解析,但是有时客户还是想坚持使用excel的格式进行上传然后解析,标准肯定实现不了,这个时候我们需要使用 第三方的解析插件来搞定此需求,常用的比较多的是使用 excel sheet js。本篇demo用于通过使用 sheet js进行简单的解析展示操作。

先说一下基本原理:

1. 通过 FileReader将上传的文件进行解析;

2. 通过 sheet js包里得XLSX.read方法进行 excel里面内容的格式化;

3. 解析相关的sheet页里面的内容。

做lightning项目,如果我们想要使用标准的DOM API,第一步,也是最关键的,我们需要先知道 lightning locker支持哪些标准的 DOM API, 比如第一步我们想要通过 FileReader去读取内容,我们需要先了解 lex下是否支持 FileReader。
通过下面图片内容我们知道lex是支持的,所以没有了后顾之忧,我们开始进行简单实现。

salesforce lightning零基础学习(十七) 实现上传 Excel解析其内容

一. 上传需要的 static resource

我们访问https://github.com/SheetJS/sheetjs下载下来 code的资源包以后,在dist目录下我们可以使用xlsx.core.min.js 或者使用 xlsx.full.min.js,demo中我们使用后者。这里有一点需要注意,我们不能直接使用这个js,否则引用程序以后,他是会报错的类似XLSX is not defined sheet js,按照下图进行修改

salesforce lightning零基础学习(十七) 实现上传 Excel解析其内容

demo中我们正常的上传了 static resource,命名为 sheetJS,对应的文件为 修改后的xlsx.full.min.js

二. 代码实现

excelImportForAura.cmp:引入static resource,展示一个 lightning input用于上传

<aura:component implements="flexipage:availableForAllPageTypes" access="global" >
<ltng:require scripts="{!$Resource.sheetJS}"/>
<lightning:input type="file"
label="上传"
onchange="{!c.excelFileToJson}"
multiple="false"
accept="xlsx"/>
</aura:component>

对应js controller:主要就是用包里面的XLSX.utils.sheet_to_json去搞定,可以查看官方API。

({
excelFileToJson: function(component, event, helper) {
event.preventDefault();
let files = event.getSource().get("v.files");
let fileReader = new FileReader();
let datas = []; // 存储获取到的数据
let workbook;
fileReader.onload = function(event) {
try {
let data = event.target.result,
workbook = XLSX.read(data, {
type: 'binary'
});
for (let sheet in workbook.Sheets) {
if (workbook.Sheets.hasOwnProperty(sheet)) {
datas = datas.concat(XLSX.utils.sheet_to_json(workbook.Sheets[sheet]));
}
}
console.log(JSON.stringify(datas));
} catch (e) {
console.log('解析失败' + e);
return;
}
};
fileReader.readAsBinaryString(files[0]);
}
})

 结果简单展示

1. 测试excel内容

salesforce lightning零基础学习(十七) 实现上传 Excel解析其内容

2. 后台解析结果

salesforce lightning零基础学习(十七) 实现上传 Excel解析其内容

总结:本篇还有很多待完善的地方,比如文件上传大小限制,可以参考上面曾经写过的博客。比如动态展示内容或者更友好的提示用户,以及内容传递到后台。这些感兴趣的小伙伴自行完善。篇中有错误地方欢迎指出,有不懂欢迎留言。

salesforce lightning零基础学习(十七) 实现上传 Excel解析其内容的更多相关文章

  1. Salesforce LWC学习&lpar;三十二&rpar;实现上传 Excel解析其内容

    本篇参考:salesforce lightning零基础学习(十七) 实现上传 Excel解析其内容 上一篇我们写了aura方式上传excel解析其内容.lwc作为salesforce的新宠儿,逐渐的 ...

  2. salesforce lightning零基础学习&lpar;二&rpar; lightning 知识简单介绍----lightning事件驱动模型

    看此篇博客前或者后,看一下trailhead可以加深印象以及理解的更好:https://trailhead.salesforce.com/modules/lex_dev_lc_basics 做过cla ...

  3. salesforce lightning零基础学习&lpar;十五&rpar; 公用组件之 获取表字段的Picklist&lpar;多语言&rpar;

    此篇参考:salesforce 零基础学习(六十二)获取sObject中类型为Picklist的field values(含record type) 我们在lightning中在前台会经常碰到获取pi ...

  4. salesforce lightning零基础学习&lpar;三&rpar; 表达式的!&lpar;绑定表达式&rpar;与 &num;&lpar;非绑定表达式&rpar;

    在salesforce的classic中,我们使用{!expresion}在前台页面展示信息,在lightning中,上一篇我们也提及了,如果展示attribute的值,可以使用{!v.expresi ...

  5. salesforce lightning零基础学习&lpar;十&rpar; Aura Js 浅谈三&colon; &dollar;A、Action、Util篇

    前两篇分别介绍了Component类以及Event类,此篇将会说一下 $A , Action以及 Util.  一. Action Action类通常用于和apex后台交互,设置参数,调用后台以及对结 ...

  6. salesforce lightning零基础学习&lpar;八&rpar; Aura Js 浅谈一&colon; Component篇

    我们在开发lightning的时候,常常会在controller.js中写 component.get('v.label'), component.set('v.label','xxValue'); ...

  7. salesforce lightning零基础学习&lpar;十四&rpar; Toast 浅入浅出

    本篇参考: https://developer.salesforce.com/docs/component-library/bundle/force:showToast/specification h ...

  8. salesforce lightning零基础学习&lpar;一&rpar; lightning简单介绍以及org开启lightning

    lightning对于开发salesforce人员来说并不陌生,即使没有做过lightning开发,这个名字肯定也是耳熟能详.原来的博客基本都是基于classic基于配置以及开发,后期博客会以ligh ...

  9. salesforce lightning零基础学习&lpar;十三&rpar; 自定义Lookup组件(Single &amp&semi; Multiple)

    上一篇简单的介绍了自定义的Lookup单选的组件,功能为通过引用组件Attribute传递相关的sObject Name,捕捉用户输入的信息,从而实现搜索的功能. 我们做项目的时候,可能要从多个表中获 ...

随机推荐

  1. RN8209校正软件开发心得(1)

    最近领导突然让我做软件了,头大啊.以前也没怎么自己独立做过软件,这次来的突然啊,面对这么大的任务量自己只能加把劲了,还等着领导给涨工资呢,哈哈... 作为编程的小白,要自己做一款上位机的软件实属不易啊 ...

  2. Windows 10简体中文最新预览版Build 9926

    Windows 10 消费者预览版全新特性: • 全新的开始菜单Win 10的开始菜单产生了较大改变,磁贴界面在原有磁贴概念的基础上进行了大幅度的调整,新的磁贴界面开始支持纵向滚动,并可以利用开始按钮 ...

  3. easy ui datagrid在没有数据时显示相关提示内容

    $(function () { $('#dg').datagrid({ fitColumns: true, url: 'product.json', pagination: true, pageSiz ...

  4. 远程mysql出现ERROR 1130 &lpar;HY000&rpar;&colon; Host &&num;39&semi;172&period;17&period;42&period;1&&num;39&semi; is not allowed to connect to this MySQL server

    ERROR 1130: Host ***.***.***.*** is not allowed to connect to this MySQL server 说明所连接的用户帐号没有远程连接的权限, ...

  5. icheck样式绑定与翻页保持

    官方文档:http://icheck.fronteed.com/ 使用基本样式 $('input').iCheck({ checkboxClass : 'icheckbox_square-blue', ...

  6. Emacs Python 自动补全--Elpy

    安装方法: 首先,安装一些依赖包: # Either of these pip install rope pip install jedi # flake8 用来检查语法错误 pip install ...

  7. java类定义、变量类型、构造函数

    1.java类class的定义 所有java程序都以类class为组织单元,java类由属性和方法组成,下面看例子: public  class  Phone{ //属性 String company ...

  8. C&num; Json解析Json &equals; &quot&semi;&lbrace;&bsol;&quot&semi;EX&lowbar;RETURN&bsol;&quot&semi;&colon;&lbrack;&lbrace;&bsol;&quot&semi;MATNR&bsol;&quot&semi;&colon;&bsol;&quot&semi;test&bsol;&quot&semi;&rcub;&rsqb; &rcub;&quot&semi;&semi;

    string jtext = "{\"jiangsu\":[{\"wuxi\":\"无锡\"},{\"suzhou\&q ...

  9. 百战程序员——JSP

    JSP全称是什么?它相比servlet有什么优势?有什么劣势? JSP全名为Java Server Pages,中文名叫java服务器页面,其根本是一个简化的Servlet设计. JSP技术使用Jav ...

  10. java 学习中出过的错误

    1. 运行异常 C:\Users\plan-B\java>java TapeDeckTestDrive.class 错误: 找不到或无法加载主类 TapeDeckTestDrive.class