uniapp和vue如何使用SheetJS导出excel?

uniapp和vue如何使用SheetJS导出excel?

SheetJS中文文档详解

一、SheetJS是什么

SheetJS是一款适用于浏览器和Node.js的开源电子表格解析库。

与其他电子表格解析库相比,SheetJS拥有强大的电子表格解析功能,即使电子表格很大,也可以轻松处理。

同时,SheetJS支持大量的电子表格格式,如Excel、CSV、OpenDocument等。

二、SheetJS的安装

使用SheetJS需要先将其安装到项目中。安装方法有两种:可以通过npm安装,也可以直接下载文件。

通过npm安装SheetJS:

sh 复制代码
npm install xlsx

直接下载SheetJS,可以在官网(https://sheetjs.com)中下载压缩包,或者使用CDN直接引入。

js 复制代码
<!--使用CDN-->
<script src="https://unpkg.com/xlsx/dist/xlsx.full.min.js"></script>

附官网github链接:https://github.com/SheetJS/sheetjs

以及官网文档:https://docs.sheetjs.com/docs/

三、SheetJS的使用

下面是将JSON数据写入到Excel表格中的示例:

js 复制代码
/* 生成数据 */
var data = [
  { name: '小明', age: 20, gender: '男' },
  { name: '小红', age: 21, gender: '女' },
  { name: '小刚', age: 22, gender: '男' }
];
/* 将JSON数据转化为工作簿 */
var worksheet = XLSX.utils.json_to_sheet(data);
/* 生成Excel文件 */
var workbook = XLSX.utils.book_new();
/* 将工作簿添加到工作簿集合中 */
XLSX.utils.book_append_sheet(workbook, worksheet, 'SheetJS');
/* 导出Excel文件 */
XLSX.writeFile(workbook, '文件名.xlsx');

上面的代码中,SheetJS使用XLSX.utils.json_to_sheet()将JSON数据生成工作簿,使用XLSX.utils.book_new()生成新的工作簿集合,并将工作簿通过XLSX.utils.book_append_sheet()添加到工作簿集合中,最后通过XLSX.writeFile()导出Excel文件。

附:导出excel的表头修改

貌似SheetJS并未直接提供表头的显示修改,默认显示data的"name","age","gender"字段,如需要显示"姓名","年龄","性别",需要自己将data数据转换,以下是博主写的转换方法:

js 复制代码
var data = [{ name: '小明', age: 20, gender: '男' }, { name: '小红', age: 21, gender: '女' }];
var header = {
	name: '姓名',
	age: '年龄',
	gender: '性别'
};
data = data.map(item => {
	let obj = {};
	for (let key in item) {
		if (header[key]) {
			obj[header[key]] = item[key];
		} else {
			obj[key] = item[key];
		}
	}
	return obj;
});

效果如:

复制代码
姓名	年龄	性别
小明	20	男
小红	21	女
小刚	22	男

四、SheetJS的更多用法

更多api方法:

js 复制代码
aoa_to_sheet //将JS数据数组转换为工作表。
json_to_sheet //将JS对象数组转换为工作表。
table_to_sheet //将DOM表元素转换为工作表。
sheet_add_aoa //将JS数据数组添加到现有工作表中。
sheet_add_json //将JS对象数组添加到现有工作表中。
sheet_add_dom //将DOM表元素中的数据添加到现有工作表中
sheet_to_json //将工作表对象转换为JSON对象数组。
sheet_to_csv //生成分隔符分隔的值输出。
sheet_to_txt //生成UTF16格式的文本。
sheet_to_html //生成HTML输出。
sheet_to_formulae //生成公式列表(具有值回退)。
相关推荐
阿奇__几秒前
uniapp支付宝 H5 开发踩坑,hash模式下取参要规范!
开发语言·uni-app
琢磨先生TT14 分钟前
为什么很多后台系统功能不少,看起来却还是很廉价?
前端·vue.js·设计
herinspace44 分钟前
如何解决管家婆辉煌零售POS中显示的原价和售价不一致?
网络·人工智能·学习·excel·语音识别·零售
一 乐2 小时前
交通感知与车路协同系统|基于springboot + vue交通感知与车路协同系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·交通感知与车路协同系统
踩着两条虫3 小时前
强强联合!VTJ.PRO 正式接入 DeepSeek V4,AI 编码能力再跃升
前端·vue.js·ai编程
云起SAAS3 小时前
小智笔记APP源码 | 8大广告联盟聚合(穿山甲/优量汇/快手/百度) | 应用市场过审极速版 | uni-app全栈商用项目
笔记·uni-app·广告联盟·笔记app
Beginner x_u3 小时前
前端八股整理(Vue 02)|组件通信、生命周期、v-if 与 v-show
前端·javascript·vue.js
万物得其道者成4 小时前
Vue3 使用 Notification 浏览器通知,解决页面关闭后旧通知点击无法跳转问题
前端·vue.js·edge浏览器
一條狗4 小时前
学习日报 20260423|[特殊字符] 深度解析:Vue 3 SPA 部署到 Spring Boot 的 404/500 错误排查与完美解决方案-2
vue.js·spring boot·学习
l1t5 小时前
duckdb excel插件和rusty_sheet插件在python中的不同表现
开发语言·python·excel