最近我在进行一些前端小开发,遇到了一个小需求:我想要将数据导出到 Excel 文件,并希望能够封装成一个函数来实现。这个函数需要接收一个二维数组作为参数,数组的第一行是表头。在导出的过程中,要能够确保避免出现中文乱码的情况。另外,考虑到数组中可能包含回车、逗号、换行符等特殊字符,咱们该如何处理这些情况呢?
解决方案
1、导出CSV文件
将一个二维数组导出为CSV文件,这种操作比较简单,这里咱们不直接依赖外部库,使用纯JavaScript在浏览器中导出CSV文件,具体的操作步骤可以如下所示:
- 将二维数组中的每一行数据转换为CSV格式,但是要确保特殊字符(如回车、逗号、emoji等)被正确处理
- 添加UTF-8 BOM(Byte Order Mark)以确保生成的CSV文件在处理中文时不会出现乱码。
- 创建一个Blob对象,将CSV数据转换为一个包含MIME类型为
text/csv;charset=utf-8;
的Blob。 - 创建一个不可见的
<a>
标签,设置href
为Blob对象的URL,并设置download
属性为导出的文件名。 - 模拟点击该链接以触发下载,然后移除该链接。
示例代码:
使用示例:
拓展知识:在
data:text/csv;charset=utf-8,\uFEFF
中,\uFEFF
是一个特殊的Unicode字符,称为“零宽度无间断空格”(Zero Width No-Break Space,ZWNBSP)。在CSV文件的开头放置\uFEFF
字符,主要是为了标记文件的字节顺序(Byte Order Mark, BOM),指示其采用UTF-8编码,帮助某些文字处理器或应用程序正确识别文件的编码方式,尤其是那些可能不默认使用UTF-8编码的程序。
这里面会有一些弊端,比如我要导出的内容包含回车等字符,这就导致用excel打开的时候,内容会把行高撑得很高,在屏幕上显示不了两行内容,但在纯CSV文件中,无法直接设置行高或格式化样式,因为CSV文件是一种纯文本格式,不支持这些样式属性。这时候就要考虑另一种导出方式了。
2、导出Excel文件
首先咱们要在项目中引入SheetJS
库。我这项目是webpack打包的,所以我通过npm安装
纯网页应用可以通过CDN引入
接下来就是根据需求写代码,我这里不仅添加了行高的设置,还对每一列做了宽度的设置,如果没有这个参数,默认列宽为30个字符,
示例代码:
问题
在使用webpack打包的时候,尽管在Webpack配置中使用了webpack.ProvidePlugin
来提供process
模块,但仍然出现Module not found: Error: Can't resolve 'process/browser'
错误,SheetJS
尝试引用process
模块,但是在浏览器环境中默认情况下没有提供这个模块。
这该怎么办呢?
1、安装需要的所有依赖,确保SheetJS
需要的依赖都存在
2、修改webpack的配置
上面的规则块的目的是为了处理
node_modules
中的.mjs
文件,使其能在 Webpack 中正确解析和打包。这对一些使用 ES 模块的第三方库(如xlsx
)特别重要,因为这些库有时会使用.mjs
扩展名但并不完全符合严格的 ES 模块规范。
最后我添加了这个规则才解决了问题,我太难了。