我的简历

Posted by Qz on June 13, 2021

“Yeah It’s on. ”

基础信息

名字,性别,电话,邮箱,求职岗位,教育经历(略)

个人技能

  • 掌握 html/css/js/ts 相关知识,掌握常⻅的⻚面布局方式
  • 掌握现代化css相关工具 less/sass/tailwind 等
  • 熟悉 node.js 在前端中的应用,熟悉koa/nest.js等框架
  • 熟悉微信小程序相关开发
  • 熟悉 electron 相关开发
  • 熟悉 vue/react/nextjs 相关,了解其关键实现原理
  • 熟悉常见的ui组件库: antd/element-ui/radix-ui/vant 等,熟悉xyflow流式可视化编排,熟悉Pixi.js 渲染引擎
  • 熟悉 webpack, rollup 和 vite,对前端组件化,工程化,自动化有一定的理解
  • 熟悉 babel,写过 babel 插件和 ast 相关处理工具
  • 掌握基本的算法和数据结构,了解设计模式
  • 了解 web rtc,了解音视频相关知识
  • 了解后端开发相关知识: go/nginx/docker/mysql/kubernetes等

工作经历

2021.4 - 至今 声网 agora 商业服务与交付中心(CSDC) web 前端开发高级工程师

  • 负责教育场景 apaas (灵动课堂) / 会议场景 apaas / ktv合唱场景相关开发,参与架构设计,协议制定,api 文档编写,协助客户解决集成中的问题等。参与灵动课堂 1.x 升级 2.0,进行代码结构重构,性能优化,工作流改造。
  • 负责RTC web场景化和开发者体验工具开发
  • 负责 AI agent的playground 和 graph designer 开发
  • 负责微信小程序音视频sdk的迭代更新
  • 担任前端面试官

2020.3 - 2021.3 晓教育集团 星火在线一对一事业部 web 前端开发工程师

  • 参与 op 运营管理系统迭代开发以及工作流优化
  • 配合设计师基于 element 组件库进行二次封装, 满足设计规范
  • 负责家长公众号以及移动端 h5 相关开发
  • 协助前端组长制定组内代码规范

2018.9 - 2020.2 小黑屋科技有限公司 web 前端开发工程师

  • 负责开发公司内部小程序框架
  • 负责开发矩阵小程序框架迁移工具,以及相关前端工作流开发
  • 负责开发 node 数据爬虫
  • 指导实习生完成日常需求

项目经历

教育场景 aPaas (灵动课堂) / 会议场景 aPaas

2021.4 - 至今 (ts + react + mobx + electorn + agora rtc/rtm sdk)

https://doc.shengwang.cn/doc/flexible-classroom/javascript/landing-page

项目概述: vaPaaS 以解决共性问题的核心模型降低 SaaS 每次迭代的成本和效率问题,可以支持客户快速集成RTC到自主品牌的产品方案里,快速搭建出教育/会议场景,打通客户不同的业务流。同时又能保证客户业务数据自主掌控,构建私域流量。

项目成果:

  • monorepo 项目管理(先基于lerna 实现,后更改为pnpm),分层架构设计(rtc/rtm sdk => core/ui-kit/widget => classroom/meeting)

  • 基于 mobx 最佳实践重构 store(domain store 和 ui store)从网状结构变为树状结构,设计生命周期钩子,采用工厂模式针对不同场景创建不同 rootStore

  • 设计统一错误处理机制,自定义Error对象,Logger采用装饰器模式区分等级/环境,结合 web worker 自动存入 IndexedDB。

  • 支持 widget插件机制,支持使用者开发自定义widget或者使用官方提供的widget。

  • 底层采用适配器模式同时支持 web 和 pc 平台,基于 async-await-retry 封装重试机制,基于mutex封装锁机制处理大量异步任务的情况。

  • 基于rc-component封装相基础UI库,利用Storybook调试和展示效果,参与花名册,投票器,白板,聊天等业务组件开发。

  • 工作流优化: webpack4 升级到 5,手动处理node polyfill,移除 cra 脚手架相关(create react app),完全自己定制化,基于 lerna 进行子包公共依赖提升,配置 sideEffects,制定不同的静态资源压缩策略,重新设计 ts config,scripts 命令优化,提取 base webpack 配置,优化 babel相关 配置,按需引入 polyfill。

  • 利用typedoc输出api文档,通过 tsc 和 rollup plugin 生成 ts dts。

Create Agora App

2024.7 - 2024.8

https://github.com/AgoraIO-Community/create-agora-app

Npm: https://www.npmjs.com/package/create-agora-app

Create Agora App 是Agora支持的创建 RTC web应用程序的快捷方式,它提供了无需配置的现代构建设置,只需一行命令即可快速创建项目。

  • 支持yarn/pnpm/npm/bunx
  • 支持vanilla/vue/react/svelte的js/ts项目模版
  • 使用 github workflows 进行 npm 发包

AI Agent

2024.3 - 至今

https://github.com/TEN-framework/ASTRA.ai

Playground:https://agent.theten.ai/

Graph Designer:https://github.com/TEN-framework/graph-designer

Astra是一个开源的多模态 AI agent,可以说话、查看和访问知识库 (RAG),基于TEN Platform。

Graph Designer 通过简单的拖放编程,集成视听工具、数据库、RAG 等,轻松构建复杂的 AI 应用程序。

项目成果:

(ts + next.js + xyflow)

  • 负责playground 相关页面搭建以及移动端适配。

  • 利用Audio Context/AnalyserNode/MediaElementAudioSourceNode等获取和处理音频数据,完成音频相关可视化。

  • graph-designer使用xyflow实现可视化工作流编排,支持Custom Nodes/Edges。

  • 使用vitest编写单元测试用例,保障数据处理/转换的正确性。

播放器

2022.1 - 2022.6 m3u8前端播放器

(videojs + react + typescript)

项目成果:

  1. 基于videojs二次封装,支持m3u8自动更新,支持自动加载策略,切片平滑过渡,可根据事件seek到指定进度。
  2. ui调整(进度条 控制栏 首帧海报 样式覆盖),基于videojs事件封装自己的事件,对外暴露控制播放器的api。

音视频小程序sdk

2021.4 - 至今 音视频小程序sdk

项目概述: 利用微信小程序 live-playerlive-pusher 组件实现音视频通话

项目成果:

  • 分层架构设计(wx socket => worker => client),解耦重构日志模块 (日志规范化,切片上传,支持客户自己收集保存日志或通过sdk api上传日志)
  • 支持以小程序原生npm方式集成sdk
  • 完善wx socket重试机制以及error捕获处理流程,对外api同时支持callback和promise返回
  • 协助文档组更新迭代官网api文档,迭代更新集成sdk的demo小程序。
  • 工作流优化: 依赖整理,支持开发环境和生产环境打包,将webpack改为rollup打包,体积优化190kb => 150+kb

web ktv 场景解决方案

2023.1 - 2023.6 web ktv 场景解决方案

项目概述: 利用web rtc sdk 和 wasm(实时监听人声声调)模块实现web端ktv实时歌唱场景,采用canvas逐帧绘制歌曲声调视图,当监听到主播端声调进行实时打分,分数满足条件时进行视图着色,combo激励动画等。

项目成果:

  • 完成UI层(歌词组件,打分组件,激励动画,粒子效果,等级视图,音调谱线组件)等组件开发。
  • 完成逻辑层engine设计开发(包括歌词解析器Parser,任务调度器Scheduler,分数计算器Calculator,声调转换器PitchChanger等)。封装MessageHandler用于主播端和观众端同步歌词信息,进度校准等。
  • 进行canvas性能优化(分层渲染),和移动端对齐相关api设计,数据结构和单元测试用例等。
  • 使用vitest编写单元测试,保证在打分逻辑等一些边界处理上和移动端保持一致。

RangeEngine

2024.1 - 至今 RangeEngine

项目概述: RangeEngine是一个基于位置信息和组队信息的音视频流管理模块,它可以让用户在元宇宙虚拟世界时不同的模式下订阅和取消订阅彼此的音视频流,实现更灵活和高效的音视频通信。

项目成果:

  • 完成RangeEngine SDK 的相关开发工作,实现地图/人物信息配置,实现有效半径可配置,用户位置采用高频/低频更新两种方式,定时更新当前人物的大/小地图信息。
  • 集成公司内部wasm模块SpatialAudioExtension 3D空间音频 和 AIDenoiserExtension ai降噪。
  • UI层实现地图动态渲染,人物移动渲染,自适应屏幕大小缩放,支持原生dom渲染和WebGL渲染(pixi.js), 实现三种不同layout展示用户音视频列表
  • 工程化相关基于pnpm的monorepo架构,UI app可直接link workspace sdk开发测试,RangeEngine SDK采用rollup打包,对外支持 umd/commonjs/esmodule规范,利用typedoc输出api文档,通过 tsc 和 rollup plugin 生成 ts dts,配置external和peerDependencies减少包体积。

op 运营管理系统

2020.3 - 2021.3 op 运营管理系统

(vue + element ui + webpack)

项目概述: 一个 b 端内部运营管理系统,主要使用角色有老师,学规,学管,销售,教培,数据分析等。

项目成果:

  1. 负责学规工作台, 学管工作台, 老师海报编辑, 课堂报告等模块开发, 重构批量导入资源模块。
  2. 参与封装通用业务组件, 通用select组件 (支持初始化回显, 高级筛选)通用table组件(自带索引, 集成分⻚器组件, 文字超出隐藏, 鼠标悬浮显示tooltip等)通用上传组件 (支持扫码上传, 剪贴板复制上传等)。
  3. 参与权限控制,自定义上报自定义命令等封装,参与系统组织架构调整开发。
  4. 工程化优化:分析webpack编译速度以及打包体积, 将@antv相关库移出vendors, 配置cache, 移除moment其他语言包,整理项目依赖, 最终编译时间从1分30s降到1分10s, 体积减少近15%。

家长公众号以及移动端 h5

2020.3 - 2021.3 家长公众号以及移动端 h5

(vue + vant ui + webpack)

项目成果:

  1. 负责课程日历,课程表,题目面板,题目展示,入学测报告, 课堂报告等⻚面, 精确还原设计稿实现复杂交互。
  2. 对复杂组件进行懒加载,基于vant组件库二次封装,同时适配部分h5⻚面在pc端的展示效果 。
  3. 基于webView jsBridge封装与app通信的相关函数。

公司内部微信小程序框架

2018.9 - 2020.2 公司内部微信小程序框架

项目概述: 由于原生微信小程序更新速度过快, 市面主流框架存在一些 bug, 难以胜任公司业务快速迭代,遂决定从零 开发公司自己的框架 ,集合公司内部沉淀下来的一些优化方案。

项目成果:

  1. 实现网络请求封装 (请求模式, 请求配置, 拦截器, 请求依赖, 请求加密, 请求重试机制等)。
  2. 实现store对全局数据状态进行管理, 内部实现observer监听数据的变更自动setData更新⻚面。针对大的Object进行diff, 提高setData效率。
  3. 采用Ioc模式实现插件化机制, 可使用内部插件, 可自己编写插件。
  4. 实现全局错误监控上报机制。
  5. 对原生wx api进行promisefy化, 实现全局通信机制, 解决长列表数据加载渲染过慢问题, 解决小程序⻚面栈最多十层的问题等。
  6. 工作流搭建:使用gulp结合npm script搭建工作流, 实现文件监听, 分环境打包, 预编译, 支持less, 静态资源压缩, 配置eslint规则,正式环境将小图标集合自动转为精灵图, 同时将其上传至阿里云。结合内部cli工具,实现矩阵小程序系列切换,集成微信命令行工具,可使用命令上传代码包。利用husky钩子检查代码,保证提交到git代码的一致性。

使用框架后,常规业务迭代从原来一星期4人4天降至3人2天,保证百万DAU级别的小程序稳定运行。

数据爬虫

2018.9 - 2020.2 数据爬虫

(koa + node-schedule + pm2)

项目概述:为了方便运营同学查找素材和编辑素材,提高运营同学工作效率。

项目成果:

  1. fiddler抓包分析接口,自动化复杂异步流程(抓取数据,存储服务器,生成json信息文件,上传腾讯云cos桶,添加水印,导入后端数据库,设置定时任务)。
  2. 负责后台系统中素材编辑的相关⻚面开发,使爬取下来的素材可以展示和二次编辑。

个人评价

积极乐观,保持良好的代码⻛格和编程习惯,对前端技术保持热情,希望加入技术氛围比较好的团队。

个人作品

  • 我的博客: https://qinzhen001.github.io/
  • 算法系列: https://github.com/QinZhen001/leetcode
  • 手写源码: https://github.com/QinZhen001/front-end-demo

针对简历问问题

  • 介绍一下叫你做过比较难的项目?难点在哪?你是怎么解决的?

英语自我介绍

你好!我叫qinzhen,我今年28岁,我有着6年前端相关开发经验。我掌握 html/css/js/ts 相关知识,掌握主要的前端框架,像是 React, Vue.is,了解 web rtc,了解音视频相关知识,了解后端开发相关知识:,例如go/nginx/docker等。在过去的三年半时间里,我在agora担任前端开发工程师的岗位,主要负责rtc相关的web场景的开发,如在线教育,在线会议,在线ktv等。Agora是一家美国上市的公司,是实时音视频云计算PaaS平台服务提供商,在agora之前,我在一家名为星火教育的教育机构主要负责B端相关业务的开发,呆了大概一年多,开发了一些如一些CRM/OP 管理后台等。这就是我的基本介绍,谢谢!


Hello! My name is Qinzhen, and I’m 29 years old. I’ve been working in front-end development for six years now, and I’ve accumulated a solid(/ˈsɑː.lɪd/) skill set along the way. I’m well-versed in HTML, CSS, JavaScript, and TypeScript, and I have a good grasp( /ɡræsp/) of major frameworks like React and Vue.js. I also have some understanding of WebRTC and audio/video technologies, which has been quite useful in my projects. On top of that, I have some knowledge of back-end development tools like Node.js, Go, Nginx, and Docker.

For the past three and a half years, I’ve been working as a front-end developer(dɪˈveləpə) at Agora, where my primary(ˈpraɪməri) focus has been on developing web applications for real-time communication (RTC). This includes a variety(/vəˈraɪ.ə.t̬i/) of online scenarios(/sɪˈnɑː.ri.əʊ/) like online education, virtual meetings, and even online karaoke!

Before joining Agora, I worked at a company called Xinghuo Education, where I was mainly involved in developing B2B solutions. My work there included creating CRM systems and operational management(ˈmanijmənt) dashboards. This experience gave me a solid(/ˈsɑː.lɪd/) foundation in understanding the needs of businesses.

In summary, I’m passionate(/ˈpæʃ.ən.ət) about what I do, and I’m always looking for new challenges and opportunities to grow. Thank you for taking the time to get to know me!