赞
踩
头部处理
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
{
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道(含答案)!
开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
资料截图 :
高级前端工程师必备资料包
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。