当前位置:   article > 正文

前端导出Excel实践指南

前端导出excel

头部处理


Mock数据: 详细数据请跳转 Github, 在 mock.ts 中查看

Header 部分数据格式

[

{

key: ‘animal’,

value: ‘动物’,

child: [

{

key: ‘dog’,

value: ‘狗’,

child: [

{

key: ‘corgi’,

value: ‘柯基’,

},

{

key: ‘husky’,

value: ‘哈士奇’,

},

],

},

{

key: ‘tiger’,

value: ‘老虎’,

},

],

},

]

Data 部分数据格式

[

{

name: ‘黄刀小五’,

desc: ‘基于搜索引擎的复制粘贴攻城狮’,

watermelon: ‘喜欢’,

banana: ‘不喜欢’,

corgi: ‘喜欢’,

husky: ‘喜欢’,

tiger: ‘不喜欢’,

},

]

头部数据处理

??? 分析

  • Header 数据为树形结构, 其深度为头部所占行数

  • Header 数据要转换成 Data 数据的格式, 并与 Data 数组合并, 共同处理成导出所需格式

  • 转换对象的 key 应为最小叶子结点的 key

  • 转换对象的 value 应为当前层级的 value ( 即导出后当前行所显示的 value )

  • 既然是树, 果断递归, 准没错

???‍♂️ Code

excel2.png

???‍♂️ Image

Merged 数据

{

s: { // start

r: x, // row

c: y, // column

},

e: { … } // end

}

??? 分析

  • 将处理后的头部数据看成一个矩阵

  • 行或列中, 相邻元素若相同, 则进行合并

tips: 本文采用的是判断相邻 value 值是否相等进行合并, 若有需求, 建议改写为对象形式加以完善.

???‍♂️ Code

excel4.png

???‍♂️ Image

生成sheet数据


  • 利用Object.assign进行对象合并

  • 利用String.fromCharCode(65 + i)对列进行大写字母的转换

???‍♂️ Code

excel13.png

???‍♂️ Image

转换字节流


利用 new ArrayBuffer(str) 创建一个缓冲区, 使用 new Uint8Array(buf) 引用

因为 unicode 编码是 0~65535, 而 Uint8Array 范围为 0~255, 故需要按位与 0xFF, 以保持位数一致

const s2ab = (str: string): ArrayBuffer => {

let buf = new ArrayBuffer(str.length)

let view = new Uint8Array(buf)

for (let i = 0; i !== str.length; ++i) {

view[i] = str.charCodeAt(i) & 0xFF

}

return buf

}

导出文件


结合前文 准备工作 部分所讲, 导出的代码逻辑就出来了, 直接上代码

总结

秋招即将开始,校招的朋友普遍是缺少项目经历的,所以底层逻辑,基础知识要掌握好!

而一般的社招,更是神仙打架。特别强调,项目经历不可忽视;几乎简历上提到的项目都会被刨根问底,所以项目应用的技术要熟练,底层原理必须清楚。

这里给大家提供一份汇集各大厂面试高频核心考点前端学习资料。涵盖 HTML,CSS,JavaScript,HTTP,TCP协议,浏览器,Vue框架,算法等高频考点238道(含答案)

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

资料截图 :

高级前端工程师必备资料包

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/笔触狂放9/article/detail/770443
推荐阅读
相关标签
  

闽ICP备14008679号