自我介绍下,四年工做经验,头两年全栈开发,后两年专职作前端,目前已达到高级前端工程师水平,经历过三家公司。第一家公司,电商行业,作阿里 ISV
供应商,为淘宝卖家服务,也是我第一次接触百万 UV
级别的产品,在第一家公司呆了两年,因为达到技术瓶颈期,随跳槽,第二家公司,航运物流行业,呆了六个月(工做强度对我来讲,是真的高),身体不适,没有赞成转正。目前这家,担任项目管理和前端组长,两个角色,目前呆了两年,作了不少东西,把本身的一些想法跟你们聊一聊。前端
这是一家作保险和金融行业的公司,属于传统行业的科技公司,有点外包的性质,固然,也有本身的 SaaS
产品,因为是传统行业的公司,技术栈相对互联网公司来讲,稍微落后一点。我刚来的时候,上一个前端要辞职了,而后作对接工做(告诉我,有啥问题,直接搜代码),我算是接盘侠,前任留下的屎山,其余的,大概有如下几点:react
其中一个归 CTO(作后端) 管,另外两个在广东,我入职的时候,也没有确认,到底要不要带人。我来的时候,就已经在了,后面我领导跟我说,要带下他们,我当时压根就没有带人的想法,也是个坑。webpack
Node
版本很是低,到如今仍是 8.x
,各类低版本的库都在,好比 Ant Design
用的 3.6.2
,在项目开发中遇到穿梭框没法进行树状显示(代码一摸同样,在高版本 3.19.2
,能够显示)。又好比还有这种 "translate.js": "git+https://github.com/MichelSimonot/translate.js.git”
React
,Redux
使用,欠缺理解。有过一次”爆炸”,此项目若是再继续迭代下去,随时可能继续”爆炸”,如今已是在踩雷开发阶段。ios
在 2019 年 10 月 18 号,24:00 发生生产事故,事故表现为,操做特定页面,浏览器崩溃,卡死。git
脚本执行时间很是长,后面经查,是由如下代码引发github
actions.getAgentListByPage({ companyId: currentAgent.companyId, pageIndex: 1, pageSize: 20000, searchProvince: currentAgent.province, searchCity: currentAgent.city })
页面不少地方存在请求 **_pageSize:20000_** 的状况,该代码是由前任前端编写,具体为什么写出这样的代码,缘由未知,处理方案给到后端解决,前端配合加入 `workbench` 字段,凌晨 1 点左右获得解决。
打包出来的项目代码体积有 49.5MB,页面首次加载耗时 11.4 minweb
基于以上的缘由,向领导提出太重构,没有赞成,我认为可能有两个方面的顾虑,axios
列举了以上的这些点,烂摊子太多了,好在有一个点,领导的支持力度还不错,看我是如何突围的。后端
前端技术建设的核心目的,是为了提升开发效率,保证开发质量,为保障项目高质量按时交付,同时兼顾考虑中长期研发实际状况,结合团队实际能力,为将来作技术储备,为业务发展提供更多的可能性,大概将本身的分为如下三类前端工程化
首先,要对现有的问题进行梳理概括,按照问题的优先级进行排序,而后,分阶段性目标进行实现,对于上面的问题,我大概整理了一张表格
问题 | 优先级 | 成本 | 目标 |
---|---|---|---|
如何打造前端工程化体系 | p0 | 高 | 提高整个前端团队的开发效率、按时交付、保证交付质量。 |
如何进行团队管理 | p0 | 中 | 进行人才储备,提升团队人员技术能力 |
如何进行项目管理 | p1 | 中 | 掌控全局,知道项目下的人都在作什么,资源协调 |
主要是指代码权限控制,目的是确保代码安全,问题可控可避免可追溯
具体管理举措有如下几条:
GitLab
,默认关闭全部外网访问权限,针对每一个项目,按实际须要给开发赋予指定权限。PR
,而后在组长进行 CR
后,才能提交到主仓库。先后端开发联调有一个严重问题,就是后端接口变更或者字段改动时,没有在事前过后通知相应前端开发,测试人员,致使效率底下,而且会出现各类异常状况。
所以,经过梳理开发流程,出接口文档,做为对接标准。
咱们使用 apiDoc
来做为先后端联调标准。
但在实际状况中,仍是会有一些接口文档和实际接口不符的状况发生,致使一些问题产生,这个咱们也在思考。
刚入职的时候,因为上面的项目框架问题太多,以前也尝试过解决,但,解决不了,领导也意识到了这点,并且也有新项目进来,就让我从新搞一套项目框架。因此,我自研了一套基于 Webpack
的项目框架和工程化体系,作这件事的目的,就如我上面提到过的同样,提高整个前端团队的开发效率、按时交付、保证交付质量。
咱们使用的是 Git Flow
分支管理策略
Git Flow
最开始是由 Vincent Driessen
发行并广受欢迎,这个模型是在 2010 年构思出来的,而如今距今已有 10 多年了,而 Git
自己才诞生不久。在过去的十年中,Git Flow
在许多软件团队中很是流行
master || main
分支上的产品要求随时处于可部署状态。master || main
分支只能经过与其余分支合并来更新内容,禁止直接在 master || main
分支进行修改。develop
分支上的产品能够是缺失功能模块的半成品,可是已有的功能模块不能是半成品。develop
分支只能经过与其余分支合并来更新内容,禁止直接在 develop
分支进行修改。feature
分支,并在 feature
分支上进行开发。开发完成后,须要将该 feature
分支合并到 develop
分支,最后删除该 feature
分支。develop
分支上的项目准备发布时,从 develop
分支上建立一个新的 release
分支,新建的 release
分支只能进行质量测试、bug 修复、文档生成等面向发布的任务,不能再添加功能。这一系列发布任务完成后,须要将 release
分支合并到 master
分支上,并根据版本号为 master
分支添加 tag
,而后将 release
分支建立以来的修改合并回 develop
分支,最后删除 release
分支。master
分支中的产品出现须要当即修复的 bug 时,从 master
分支上建立一个新的 hotfix
分支,并在 hotfix
分支上进行 BUG 修复。修复完成后,须要将 hotfix
分支合并到 master
分支和 develop
分支,并为 master
分支添加新的版本号 tag
,最后删除 hotfix
分支。提交信息应该描述“作了什么”和“这么作的缘由”,必要时还能够加上“形成的影响”,主要由 3 个部分组成:Header
、Body
和 Footer
。
Header
Header 部分只有 1 行,格式为<type>(<scope>): <subject>
。
type 用于说明提交的类型,共有 8 个候选值:
subject 用于归纳提交内容。
Body 省略
Footer 省略
这样作起来的好处,这个项目下:
Tag
都上线了什么内容。总之,一目了然。
在这个流程中,开发人员只对我的仓库拥有可控权,没法直接改变公司仓库代码,当须要提交到公司仓库下时,须要发起 PR
请求,通过组长 CR
后,将其代码合并到公司仓库下。
主分支代码和线上代码进行隔离,由组长将指定版本的 Tag
发布到生产环境,再经过运营人员直接从 GitLab
上拉取指定的 Tag
,而后打包发布。
经过以上流程,前端代码能保证高质量,高稳定性的状态,运行在服务器端。
要根据实际业务状况和团队规模,技术水平来作,关键是要造成一个闭环,所谓闭环就是从零开始到上线再到迭代的全链路,有不少节点,这些节点须要根据实际状况进行设计,避免过分设计。
为什么不是 create-react-app
create-react-app 是基于 webpack
的打包层方案,包含 build、dev、lint
等,他在打包层把体验作到了极致,可是不包含路由,不是框架,也不支持配置。因此,若是你们想基于他修改部分配置,或者但愿在打包层以外也作技术收敛时,就会遇到困难。
为什么不是 umi
umi 提供的功能不少,这也致使它太过于臃肿。并且你还要去学它的封装化配置,而不是学原生第三方库的配置,若是你只想要一些简单的功能,追求更高的可玩性,哪 umi 不太适合。
因此,我本身定制了一套脚手架,实现了如下功能:
解决了如下的问题:
完成整个编码过程的一个闭环:
这些节点要视实际状况,以最小成本去作,而后逐步升级。好比编码规范,咱们是采用业界比较著名的 Airbnb JavaScript
代码规范,搭配eslint、pre-commit、lint-staged、prettier、stylelint
去进行约束。
这套项目框架,目前开发体验很是爽,在我司多个产品线上,投入使用,并已开源,框架地址,演示页面比较少,大佬们以为不错的话,能够给个 Star 🌟,也欢迎给项目提 issues ~
咱们是作 ToB
业务,存在页面上大量使用表单的场景,因此,把咱们的表单页面作成可配置化,实现了大部分页面表单配置化,减小前端人力资源投入。
针对公司的实际业务场景,其余子系统不会特别复杂,页面也不会多,共享一套帐号体系,这里采用的思路是只有一个项目,不分主从系统,经过 Webpack
配置多页面,不一样的子系统进入的首页内容不同,加载内容不同,菜单导航,则经过后端对每一个租户进行区分,来作到租户看到的菜单系统不同。
若是子系统特别复杂,有主从系统概念,能够考虑使用微服务设计,这里不作过多介绍。
除了业务代码之外,前端还会有一些公共静态资源,例如 React
资源,Ant Design
资源,BizCharts
资源,以及一些图片文件等。
对于这些文件,是全部项目所共享的,假如这些文件分散在各个项目里,既不必,也容易致使不一样项目依赖文件不统一。
咱们是放在 S3
上,作 CDN
静态资源加速,而后前端项目经过引入url
来使用这些资源,这样能够减轻本身的服务器网络带宽消耗。
所谓技术服务业务,找产品了解现有的业务流程以及痛点,甚至将来要作的一些产品规划,好的技术架构,要考虑各类各样的业务场景,怎样才能结合业务的复杂度,设计出颗粒度更加细化的组件。
画出产品架构图
需求频繁且混乱,决策摇摆不定、动辄推倒重来。市面上一个好的产品经理是很贵的,没个三四万是拿不下一个真正靠谱的能抗住复杂产品线的产品经理,可是不少公司老板是不肯意花这个钱,通常就会招个工做一两年的产品经理先过来,顶个位置把这个工具给作出来就好了。偏偏由于这样一个认知致使产品经理这一层他既没话语权,又不能让本身闲着,因此层出不穷的需求全堆上来了,而对于公司长久型的产品架构就把控不住,若是一个产品经理没法起到,上对客户负责,下对开发负责,不会对全部需求进行筛选,把需求只会丢给开发,不会进行工时把控和质量把控。甚至对现有产品有什么功能,都不了解,那么就不是一个合格的产品。
因此对产品经理的要求很是严格,由于一个公司,若是战略方向把握住了,那么核心是要看产品,可否把握住市场方向,很是关键。这样才能决定你是否能占有市场,因为我司是作一个 ToB SaaS
化的平台,因此,必需要求产品经理清楚的了解客户实际需求,需求背后的实际场景,提炼出来哪些是共性的需求,哪些是客户定制化的需求,而后再讨论,再进行落地实际的开发。
对测试人员,尽可能覆盖全全部场景,保证核心流程畅通,要求能找到复现步骤,提升开发解决 BUG 的效率。
因为我司采用的是 Ant Design
UI 库,因此设计标准,尽可能都是按照 Ant Design
现成组件和样式来作,避免开发二次修改,参考这个连接 Ant Design 设计原则
某个列表页
普通的列表,和设计,产品都约定好,上面是筛选,下面是按钮,底部是表格展现。
某个详情页
详情页大量会使用到表单,因此直接使用 Ant Design
的 From
表单组件。
表单每行放多少个,都是以 Ant Design
组件来的。
这样带来的好处就是尽可能避免定制化的开发,全部列表和详情都是按照这种风格来进行开发。
上面这些,包含其余的,大概花了一年多的时间,建设完成,咱们目前的基建情况以下表所示
前端人员的开发效率较以前,提高了一倍左右的开发效率,前提是彻底熟悉我这套项目框架的开发模式。
项目管理,人员工时占比,资源协调,目前下来都还不错,平稳进行。
若是你以为对你有帮助或启发,欢迎点赞留言。