作者 | 张旭乾 责编 | 梦依丹
出品 | CSDN(id:csdnnews)
前端和后端开拓,哪一个更随意马虎上手?我们时常会在各大技能论坛看到类似的提问。话说兴趣是最好的老师,不实践,你可能很难知道自己更喜好哪一个?

从Java开拓再到前端工程师,他在转型路上碰着过哪些困难?本文作者张旭乾分享了他的转型经历,以及他在学习前端开拓过程中,碰着的问题和总结出来的一些履历,希望对你有所启示。
我的学习经历
编程入门
在 2008 年的时候,我进入大专学习 Java 开拓,HTML 和 CSS 只是专业的附属品。那时,紧张还是前后端一体化开拓,HTML 和 CSS 只是为了却合 Java 里的 Servlet 天生页面。JavaScript 则完备没有讲。
2010 年快毕业的时候,我参加了五个月的 Java EE 培训,在这期间理解了 HTML、CSS,以及一部分大略的 JavaScript DOM 操作和 jQuery,能够编写一些带交互的页面和 Ajax 异步要求。
在这期间,我没有太重视 HTML/CSS/JS 根本。由于本身刚入门,并不知道哪些主要,哪些不主要。在做项目的时候,页面部分要自己在网上搜索 HTML 标签和 CSS 属性的用法。对付 JS 部分,则只会 jQuery,高等的语法(例如闭包、原型链)完备没有观点,只知道该怎么定义变量,处理事宜,做一些基本的逻辑处理。
顺利转正,还加薪10%
我的第一份事情是 Java 开拓,当时公司用的技能很新潮,算是前后端分离的雏形。页面部分完备利用了 ExtJS 库,它供应了一组现成的 UI 组件,所有的数据都是通过 Ajax 来从后端获取,后端则用 Java 的 Servlet 供应JSON 数据。
这份事情的紧张难点是一开始不理解前后端分离的开拓模式。由于是第一次考试测验完备在客户端 JS 去要求数据,以是理解起来须要一点韶光,当时阅读了 ExtJS 干系的文档,才大体的理解到这种开拓模式。基本上是利用 Ajax 要求数据,然后通过它内置的 API 来添补 UI。后面随着开拓的功能变多,对这种模式也适应了。
努力学习还是有回报的,过了三个月试用期之后,由于事情比较出色,在拿到正式员工薪资的根本上,又额外加薪了 10%。以是刚进入公司的时候不要怕上不了手,主流的技能碰着不会的地方要长于自行查找资料办理,对付公司内部的技能要勇于向前辈请教。
自由职业:实践与进阶
2010 年底从第一家公司离职,回到家里自己充电,学习了 PHP。由于当时建站非常盛行,学了 PHP 既可以做个人站长,也可以通过自由职业,为客户建站来赚取收入。由于支配网站的主机基本上都支持 PHP 和 ASP,而 PHP 更加盛行,以是我就自学了 PHP,通过官方文档,加上实战并结合搜索引擎搜索问题来学习。学完了之后就在网上发了个广告,供应个人建站做事,此时的我还是全栈开拓。
2011 年底旁边,广告发完了我就忘了,没把它太当回事。大年初六溘然收到一个客户的电话,须要做一个网站,这让我愉快不已。我给这位客户一共做了两个网站:
一个是论坛,直接二次开拓的,修正了一下样式。
一个是质量担保查询系统,从零利用 PHP + MySQL + jQuery + jQuery UI 进行开拓。
真正有寻衅的是第 2 个项目,页面部分险些碰着了前端开拓中全部常见的难题:
JS 代码管理
当时 UI 部分选择了和 jQuery 配套的 jQuery UI。jQuery UI 封装了一组常见的 UI 组件,例如拖拽、对话框、按钮等组件,可以少写一些逻辑代码。只管如此,编写出来的 JavaScript 文件还是乱七八糟,由于页面上有很多表格组件,须要在获取数据后,手动去循环展示表格,并在删除或修正的时候,还要修正 DOM 更新表格;其余还有其它逻辑,例如登录、查询等。
虽然代码分散在了不同的 JS 里,但是有的页面由于业务逻辑比较繁芜,加上当时我也不太理解 JS 的复用办法和逻辑,导致了很多重复的代码。我还有当时的源代码,可以感想熏染一下代码的长度(两张图片为同一 JS 文件的不同部分,这里通过缩略图展示):
一个 JS 文件中的代码
兼容性调度
彼时,浏览器主流的还是 IE,以是还是须要做一些兼容性调度。不过好在 jQuery 主打的便是兼容全部浏览器,以是 JS 方面没有太大问题,剩下的便是 CSS。这个项目在 IE、Chrome、火狐下显示的都不一致,后来查了一下,办理方法可以根据浏览器特定的语法,编写只在特定浏览器能识别的 CSS 属性,或者选择器,也便是所谓的 CSS hacks。其余也可以利用浏览器分外的 HTML 指令,加载不同的 CSS 文件,终极把页面调成同等就可以了。
性能调优
由于项目页面部分处理数据比较多,加上开拓履历有限,当时也只是在代码效率上进行了优化,例如减少不必要的循环操作等。
与客户沟通需求
这个是开拓的软技能了,学会如何谢毫不合理的需求。由于当时我是第一次面对客户,也没有自傲,以是客户说改什么,我急速就开始给他改。这期间客户最常见的话术便是:“这个功能很大略,你做一下”,或者“这个问题很随意马虎办理,花不了你几分钟”。当时我真以为功能或者问题挺大略的,但是实际操作起来,创造要比想象的难多了。做了几次之后,知道无论多大略的功能或问题,都会涉及很多的细节,所往后面客户再提要求的时候,我就把这些细节先说清楚,给他一个大概的落成韶光,再加上新增的功能须要额外收费,客户就会自己推敲要不要做了。
网页设计水平
还有一个意外,让我学了一部分设计知识。在给这个客户做质量担保系统的时候,还哀求附带一个产品的官网,客户给我发了产品资料之后,我参考网上同品类的网站,帮他设计了一版,但是客户以不足大气为由,让我重新设计,我又设计了一次,客户还是以为不足好,反复几次,彷佛无法知足他的需求,他就把官网这部分给别人做了。当时我也有点憋气,于是买了本《写给大家看的设计书》,专门学习了一些设计原则,努力提高自己的设计能力。后来等客户的官网上线之后,创造设计的也一样平常,大概是审美不同吧。
在自由职业后半段韶光学习了其它的框架,那个时候 Bootstrap 3、Foundation 之类的 HTML/CSS 框架开始爆火,由于十分喜好学习新的技能,我就去看了看它们的先容,看到 Bootstrap 3 内置了很多组件,并且不怎么须要写 CSS,就学了一下 Bootstrap 3。Bootstrap 3 内部利用了 LESS 这个 CSS 预编译工具来天生 CSS,如果要自定义它的样式,还须要会 LESS。我就又看了一下 LESS 的文档,创造它供应了很多实用的功能,例如变量、继续、嵌套等,觉得很故意思也顺便学了。
从这里你就可以知道:前端库是相互依赖的。如果直接看前端须要哪些库,那么零零散散的有一堆,但是当你真的开始下手学习一个框架的时候,你会创造好多框架可以从一条线里牵出来,构成一个完全的开拓工具库,这些自然就都节制了。
初识 Vue前边所有的经历,奠定了我转型前端所须要的技能根本。而在从事自由职业期间,我创造我还是喜好看做得见的项目,从 0 设计界面,直至实现出来,很有造诣感,并且我也享受在设计过程中,灵感迸发的快乐,心底就有了想转前真个火苗。不过第 2 份事情,从 2013 年到 2016 年,我仍旧做的是 Java 开拓。
真正让我对前端产生兴趣,是 2016 年去留学之后。在 2017 年第一个学期,有同学问我 React 的问题,我不太会,于是就上网帮同学查,查着查着,就创造前端已经独立作为一个职业了,再接着从 React 文档找问题的办理方案时,创造之前我用 jQuery 的问题在 React 中全部都办理了,可以不用手动掩护数据和 UI 之间的同步了,这让我感到很欣慰,起誓等这学期放暑假,就深入学习一下。
很快,暑假就到了,要兑现承诺开始学前端。当时室友学了高等 Web 编程,紧张讲的是 React,React 在那个时候还非常难用,该当还是 React 15,须要手动配置好多东西:Babel、Bower.js 之类的。看着室友碰着一个组件显示不出来,经由一天的搜索办理方案,才创造是组件名大小写不一致导致的,这个让我有点对 React 好感度降落,不想学了。
后来我就研究了一下 Vue,创造普遍的说法是:功能和 React 类似,但是海内用 Vue 的多,国外用 React 的多。看了下 Vue 是华人尤雨溪开拓的,很佩服,听说上手比较随意马虎,于是就决定先看看 Vue。
在把 Vue 官方文档根本部分看完之后,结合 YouTube 的一些***所教授的开拓方法,大概一周的韶光,以为可以上手了,就想了一下练习项目。当时理解到 Vue 适宜开拓单页运用,看了一下单页运用的特点,创造彷佛便是网页版 App 的观点。 于是,我就想着把当时我用的最多的网易云音乐模拟一下。花了一周多的韶光,实现了首页 UI、添加歌曲,播放、停息、快进、快退等功能,期间学会了 CSS flex 布局。
利用 Vue 仿网易云音乐(左)的终极界面(右)
后来创造网页版的功能局限性比较大,想着能不能做成桌面真个。当时室友在学校的课里学 Electron,一个跨平台的桌面开拓框架,只用编写 HTML、 CSS 和 JavaScript ,就可以天生在 Mac、Windows、Linux 操作系统都能运行的运用。于是我又把运用迁到了 Electron 上面。
从 Electron 这里也理解到了,Node.js 到底和浏览器 JS 运行时到底有什么不同:在 Node.js 的环境下,可以访问更底层的操作系统级 API,例如访问本地文件,这样可以方便用户自行添加音乐。
做这个项目的时候,也碰着了很多问题:
不知道什么时候须要定义成组件。刚刚接管这种组件化开拓的办法之后,最大的难题便是怎么才知道该不该把一部分 UI 定义成组件。当时的思路便是,我先把所有的页面代码都写在入口组件里,后面再根据页面的布局,把这个组件拆分成各个部分,例如侧边栏、播放列表、播放掌握器等,这样的分法彷佛很合乎逻辑,不过这也带来了一个问题。
组件和数据杂糅到了一起。项目当时利用了 Vuex,运用的数据全部交给了它去管理,对付项目的功能逻辑,都是直接在干系的 UI 中实现的,并绑定了 vuex 的数据。例如播放进度条,它和歌曲的播放韶光数据绑定了,后面要实现音量进度条的时候,创造这个组件无法复用。因此,我又把 UI 和数据分离了出来,这样的组件,可以在各处复用,之后再实现对应的逻辑就好了。
CSS Flex 布局碰着坑。这个项目利用了当时开始盛行的 CSS Flex 布局,本着学习的态度利用它,碰着了很多问题,例如父容器对 flex 缩放的影响,如何让 flex 元素占满容器,又或是如何让 flex 不占满容器等等,这些在看了 MDN 文档的先容,理解了 flex、align-items 和 justify-content 各个属性值的浸染和含义之后,就清楚了元素的缩放逻辑。
通过这个小项目的开拓,对 VUE 算是入门了,还得出了却论:
学前端,或者任何编程知识,一定要结合实践才能快速入门并节制它们。
受挫转型前端,考试测验 React
学完 Vue 之后暑假差不多也快结束了,末了一个学期都在努力学专业课,没有再看前审察干的东西。2018 年返国之后,开始找事情。由于留学的紧张方向是分布式和云打算,以是我还是想以 Java 开拓为主。口试的时候遭到了很多不屑,大多是看我刚研究生毕业,而以前的开拓经历也没什么出彩的地方,就都草草了事了。这些经历让我很受打击,但是让我清楚的知道了,纵使有一肚子墨水,但是拿不呈现实的产品,或者知足不了口试官的喜好,就不可能口试成功。
当然我不会否定自己,末了一次口试失落败之后,溘然就想要不要转业做一下前端,毕竟留学的时候研讨了不少,又在自由职业的时候做过一些产品,更是有浓厚的兴趣,于是我急速下了决心转前端。
下定决心之后,我一刻也没闲着,开始看前真个事情哀求。在某招聘 App 上搜了一圈,创造 React 在大厂用的多、人为也高一点,我就又开始自学 React,花了一周看了看官方文档,写了一个特殊小的、只有一个页面的小例子,之后就开始投简历了。期间还看了看 React Router、Redux,以及 ES6 的新特性。
在阅读 React 官方文档的时候,创造有一节是《Thinking in React》,里边详细的先容了 React 组件化开拓的步骤,并且阐明了什么时候须要定义组件,文档供应了一个表格 UI 作为示例,把它拆解成了表格整体、搜索框、表格内容、种别行和产品行组件,解释了为什么这么拆解,有没有其它拆解的方法,以及拆解过程的方案折中,建议看一看。
图片来源:https://reactjs.org/docs/thinking-in-react.html
口试后端频繁受挫 正式转型前端
以为准备的差不多了之后,就开始投简历了,大约 1 个月的韶光,收到 3 家口试,只通过了 1 家。没过的那两家同样也是见我刚毕业,连前端开拓履历都没有,就草草了事了。通过的这家,口试官是我事情时的技能总监和组长,在口试的时候没有刻意刁难,只是问了些框架方面的根本问题,还问了一下我平时是怎么办理问题的。后来,我在事情的时候,问他们为何决定让我入职,他们见告我,看中了我的学习能力。
以是口试如果没履历的话,就努力解释自己的学习能力,总会有口试官欣赏你的。我到现在还非常感谢两位,让我正式进入了前端开拓的行列。
进了公司就开始了日常做项目,大大小小一共做了 3 个,这期间经历了逻辑混乱期、尝到甜头期和精进技能期,积累了大量的开拓履历。
逻辑混乱期第 1 个项目,是改造一个传统的项目,按技能总监的建议,利用 React + dva.js 框架。UI 方面,项目之前用的是 Bootstrap,我用了 React Bootstrap 把项目迁移了过来。
这个项目里碰着的问题是:代码混乱。这个期间由于刚刚上手 React 开拓,对付代码的管理也没有太大的观点,加上 dva.js 的项目构造也不同于普通的 React 项目,以是这个项目开拓起来有点麻烦,再加上项目的逻辑比较多,导致组件的代码很长很长,复用起来也很困难(俗称面条式代码),不过由于这个项目也不是完备对外公开的,并且利用频率较低,以是就没在优化。
尝到甜头期第 2 个项目,是做一个公司内部用的运营管理后台,韶光大约是 2018 年底,当时 React alpha 测试版出了 hooks。看了一下官方文档,觉得很神奇,能够清晰地分离组件 UI 和逻辑,该当能给代码管理供应不小的帮助。虽然是测试版,但这个项目是完备对内的后台项目,以是果断的用上了。
这个项目的后端比较分外,一位大佬同事搭建了 GraphQL 做事,之前在留学的时候就已经听同学提到过很多遍了,现在有机会体验体验了。在看 GraphQL 官方文档学习、以及利用搜素引擎搜索的时候创造,利用 GraphQL 后可以不用 Redux,于是这个项目我只用了 React、 React Router 和 Apollo-GraphQL 这几个紧张的库。
这套技能加上 React hooks,让我真正感想熏染到了前端开拓的乐趣。组件从类的形式转换成了函数形式,代码量减少了很多,公共的逻辑也能抽离成 Hooks,在各个组件利用,组件自身的逻辑也能抽离成 hooks,来让功能和 UI 展示代码分开,让代码更易读。这样,整体的开拓效率提高了不少。
UI 方面则考试测验了 Ant Design,由于纯后台的,没有设计稿,只有产品原型。
其余这个项目是基于 Create-React-App 脚手架创建,理解到脚手架供应的功能非常全面,像静态资源(图片、字体)管理、插件、打包构建等都包括了,省了很多手工配置。
精进前端技能期第 3 个项目,是一个从 0 开始、面向客户的运用,UI 是由设计师专门设计,有很多自定义的样式。这是我积累最多前端开拓履历的项目,从技能选型,到组件方案,再到代码复用,对前端开拓的架构有了全新的认识。
样式管理为了研究怎么在 React 项目中管理样式最方便,我开始研究大型项目中的 CSS 样式管理,理解到有普通 CSS 和 CSS-in-JS 两种方案之后,再查资料创造 CSS-in-JS 方案更灵巧,能够在 CSS 里访问 JS 变量,让组件样式可以随着组件状态的变革而变革。
决定用 CSS-in-JS 方案之后,我找到了 GitHub Star 数比较高的 styled-components 库,它支持 CSS 嵌套、主题等功能,并且能够访问组件的属性,而且它定义的样式,本身也是一个 React 组件,可以直接在 JSX 中利用。
UI 库连续利用了 Ant Design,不过也便是利用一下它的组件功能逻辑,样式险些全部都修正了。
全局状态的取舍项目后端这次没有用 GraphQL,我又创造不用 GraphQL 也没必要利用 Redux,以是就没有再添加 Redux,结果也证明我的选择是对的:项目本身没太多全局状态,舍弃 Redux 大概让开发效率提升了 1 倍,之前像表单这样的组件大概须要一天才能完成,现在只须要半天。不过项目里有个内嵌的谈天系统,须要用一点全局状态,我就从网上查找了一些办理方案,创造利用 React Context + useReducer Hooks 的办法实现全局状态管理就够了。
提升学习能力这个项目利用的新框架都是一边看官方文档一边学习的,有不好办理的问题,就结合搜索引擎和 GitHub Issues 办理。
改良前端项目构造对付项目的构造,这次利用了就近原则来组织代码,每个组件放到单独的文件夹中,组件干系的 styles、图片、hooks 等都放在同一个文件夹,对付公用的部分,则放到项目顶级的 src 目录下。API 和其它库的配置项也都放到单独的文件夹里,同样遵照就近原则,这样管理项目就方便多了。
磨炼沟通能力这个项目的图表也比较多,为了和 App 端保持同等,选择了 Echarts。在利用 Echarts 的时候,虽然能够实现大部分设计稿中的样式,但是还是有小部分不能精准还原,在拿其实际效果跟设计师沟通之后,有些样式就做了些调度,或直接舍弃了。
项目末了验收的时候,还须要跟 UI 设计师核对样式,这期间我和设计师找了单独的工位,每天都是在沟通哪里的设计须要修正,哪里的设计不好实现,若何取一个大家都满意的折上钩划。这些在理解设计根本原则之后,你也会明白设计师设计的意图和用意,这样用理解的心态来沟通,再辅以技能上的难度展示和韶光需求,就能够更好的避免不必要的 UI 改动和代码重构。
前端工程师的技能哀求
先看一下前端工程师须要节制哪些技能。
综合大、中、小企业的前端工程师技能需求,实际上前端工程师的职能包含以下职业中的 1 种或多种:
网页开拓工程师
网页设计师(UI)
用户体验工程师(UE)
最主要的职能是网页开拓,包括小程序、APP 等跨端运用界面的开拓,虽然它们实现的技能不同,但实质上还是做页面。
前端工程师必备的技能有:
利用 HTML + CSS,精准地还原设计稿,制作符合哀求的页面。
利用 JavaScript 给页面添加交互,懂得 DOM 操作和 Ajax 要求。
节制 React 或 Vue 等主流框架的一种或几种,并理解随着这些框架的工程化,所牵扯的一系列工具(不同工程须要不同的工具,这里列出常见的), 例如:
Node.js 与 npm。
Webpack、SnowPack、Vite 等打包工具。
Create React App、Vue CLI、Vite 等脚手架。(Vite 既包含脚手架,也包含打包工具)
Gulp、Grunt 等自动化工具。
SASS/LESS 等 CSS 预编译工具。
styled-components、emotion 等 CSS-In-JS 库。
ESLint 语法检讨工具。
Jest、mocha 等测试库。
兼容性调度,利用 CSS hacks,或 JS Polyfill,实现跨浏览器页面表现同等。
性能优化,减少文件体积,减少要求次数,延迟加载图片和脚本等。
SEO 搜索引擎优化,提高网站在搜索引擎的排名。
其他的一些框架或技能,如果事情哀求,也须要节制:
SSR 做事端渲染框架,例如 Next.js(React)、Remix.js (React)、Nuxt.js(Vue)。
SSG 静态网站天生器,例如 Next.js、Gatsby、VuePress 等。
TypeScript。
GraphQL。
PS/Sketch/Figma,能根据须要进行切图,或者自行设计页面。
下面这些技能不是必须的,但是如果能节制,可以提高事情效率、跟后端或设计师沟通的能力,以提升求职升职的竞争力:
网页设计,理解设计基本原则。
用户体验设计,理解网页的动效、赞助功能对用户体验的影响。赞助功能(可访问性)在国外比较重视,目的是方便有阅读障碍的人士,利用屏幕阅读器进行网站浏览。如果你想去外企,这些技能是必须要节制的。
Docker,理解如何把前端项目构建为 docker image,会编写大略的 docker file。
后端措辞、框架、数据库,任选一套,例如 Java + Spring + PostgreSQL,Express + Node.js + MongoDB 等,理解 RESTful API 开拓过程。
乍一看要节制的有很多,但很多库都是随着 React、Vue 等最主要的前端库自然而然地引入进来的,大部分的用法都很大略,并且我们还会在事情中持续学习,一开始只须要入门就行。下图展示了 React 前端开拓工程师,根据 React 框架所衍生的技能栈(示意):
React 前端工程师技能图谱(示意)
离职,做自己感兴趣的事
2019 年从公司再次离职,不想再打工了,借鉴在国外留学时所学到的履历,转型开始做***和线上传授教化,运营着“峰华前端工程师”账号,同时也在 CSDN 揭橥博客。在这期间还撰写了《JavaScript 根本语法详解》一书。
编写书本的时候,又是一次学习的过程,在查阅各种资料之后,对 JavaScript 有了更完备的认识。同时也明白了,人只有存在目标的情形下,才会有动力去完成看似不可能的事,避免浑浑噩噩度日。
如果你像我一样,也算比较大龄的程序员,熟年龄焦虑,可以适当的想想还要不要在公司里连续事情下去,是不是该拿出勇气来考试测验做自己真正想做的事,之后利用兴趣养活自己。这不是一条随意马虎的路,以是在决定之前一定要做好两年之内没有转机的打算,这些如果我能总结出一套履历之后,再来分享。
学习建议
这些大体便是我学习、节制前端开拓的过程,总结了下面这些重点:
学会独立学习。前真个框架太多了,并且常常涌现新奇特框架,必须要能自己独立通过官方文档和搜索引擎进行学习,由于前端框架多数比较小众,不会有很多干系的教程。如果连文档都没有,就要学会读源码学习用法。
根本打牢。前端库虽然多,但万变不离其宗,总是要回归到 HTML、CSS 和 JavaScript 上面,以是根本一定要打牢,尤其是在 ES6 往后涌现的新特性,在前端用场非常广泛。
实战练习。学完前端库之后,一定要找个小项目做,把学到的东西真正地节制。Github 上有很多前端项目灵感的库,可以搜索 “front-end project ideas\公众 找到 ,或者你也可以改造模拟市情上的网站、App 等。
不要把前端只局限在技能层面。向上往设计和产品扩一下,向下从后端和运维钻一下,你会更能从整体角度不雅观望全体项目,从而在前端技能选型、开拓过程以及和同事沟通的时候,懂得取舍和折衷。
线上文档。对付 HTML、CSS 和 JavaScript 最威信的文档便是 MDN。其它的像 React、Vue 等框架,便是官方文档。如果碰着了问题,就去搜索引擎搜索,看其他人写的办理方案。
书本。对付体系化的教程,可以购买干系的书本看,重点看专业、经典的书本,这些网上有很多推举。书本可以帮助你快速入门并深入,不用在网上东找西找了。
***。现在***平台正火爆,不要只用来消遣,上边也会有很多编程干系的***,空余韶光可以刷一刷,可能会得到一些开拓灵感、技巧,以及未来事情可能用到的新技能。
在线课程或培训。在线课程或者培训能帮你直接学到和就业干系的技能,积累项目实战履历,但是要把稳鉴别课程和机构的质量。
向有履历的人学习。如果你看到有高等工程师发布的博客、微博、***等内容,可以考试测验和他们建立联系,拿出你学习的诚意,让他们帮你指示迷津,或许能少走一些弯路。
END
造诣一亿技能人