`
daicy
  • 浏览: 435 次
  • 性别: Icon_minigender_1
  • 来自: 上海
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

如何成为一名卓越的前端工程师(转载)

阅读更多
读了这篇文章,自己总结了几点
第一是要写代码的时候,不能光顾着实现,多去想想为什么会这样。
第二是要写自己的js库,css库,在写的过程中,你遇到了麻烦,那些开源的库就会给你提供参考。
第三是好的团队也很重要。
第四是做好笔记,自己写DEMO。
第五是阅读别人好的代码。
第六是阅读规范的文档。
----------------------------------------------------------------------
最近我收到一封读者来信让我陷入了思考,信是这么写的:

    Hi Philip,您是否介意我问您是如何成为一名卓越 (great) 的前端工程师的?对此您有什么建议吗?

我不得不承认,我很惊讶被问这样的问题,因为我从来不觉得自己是个很卓越的前端工程师。甚至我入行头几年时并不认为自己可以做好这一行。我只确定自己比自己想象中还才疏学浅,而且大家面试我的时候都不知道从何问起

话虽这么说,我到现在做得还算不错,而且成为了团队中有价值的一员。但我最终离开 (去寻求新的挑战——即我还不能够胜任的工作) 的时候,我经常会被要求招聘我的继任者。现在回看这些面试,我不禁感叹当我刚开始的时候自己在这方面的知识是多么的匮乏。我现在或许不会按照我自己的模型进行招聘,即便我个人的这种经历也有可能成功。

我在 web 领域工作越长时间,我就越意识到区分人才和顶尖人才的并不是他们的知识——而是他们思考问题的方式。很显然,知识在很多情况下是非常重要而且关键的——但是在一个快速发展的领域,你前进和获取知识的方式 (至少在相当长的一段时间里) 会比你已经掌握的知识显得更加重要。更重要的是:你是如何运用这些知识解决每天的问题的。

这里有许许多多的文章谈论你工作中需要的语言、框架、工具等等。我希望给一些不一样的建议。在这篇文章里,我想谈一谈一个前端工程师的心态,希望可以帮助大家找到通往卓越的道路。
别光解决问题,想想究竟发生了什么

很多人埋头写 CSS 和 JavaScript 直到程序工作起来了,然后就去做别的事情了。我通过 code review 发现这种事经常发生。

我总会问大家:“为什么你会在这里添加 float: left?”或者“这里的 overflow: hidden 是必要的吗?”,他们往往答道:“我也不知道,可是我一删掉它们,页面就乱套了。”

JavaScript 也是一样,我总会在一个条件竞争的地方看到一个 setTimeout,或者有些人无意中阻止了事件传播,却不知道它会影响到页面中其它的事件处理。

我发现很多情况下,当你遇到问题的时候,你只是解决当下的问题罢了。但是如果你永远不花时间理解问题的本源,你将一次又一次的面对相同的问题。

花一些时间找出为什么,这看上去费时费力,但是我保证它会节省你未来的时间。在完全理解整个系统之后,你就不需要总去猜测和论证了。
学会预见未来的浏览器发展趋势

前后端开发的一个主要区别在于后端代码通常都运行在完全由你掌控的环境下。前端相对来说不那么在你的掌控之中。不同用户的平台或设备是前端永恒的话题,你的代码需要优雅掌控这一切。

我记得自己 2011 年之前曾经阅读某主流 JavaScript 框架的时候看到过下面这样的代码 (简化过的):

var isIE6 = !isIE7 && !isIE8 && !isIE9;

在这个例子中变量 IE6 为了判断 IE 浏览器版本是否是 6 或更低的版本。那么在 IE10 发布时,我们的程序判断还是会出问题。

我理解在真实世界特性检测并不 100% 工作,而且有的时候你不得不依赖有 bug 的特性或根据浏览器特性检测的错误设计白名单。但你为此做的每一件事都非常关键,因为你预见到了不再有 bug 的未来。

对于我们当中的很多人来说,我们今天写的代码都会比我们的工作周期要长。有些我写的代码已经过去 8 年多了还在产品线上运行。这让人很满足又很不安。
阅读规范文档

浏览器有 bug 是很难免的事,但是当同一份代码在两个浏览器渲染出来的效果不一样,人们总会不假思索的推测,那个“广受好评”的浏览器是对的,而“不起眼”的浏览器是错的。但事实并不一定如此,当你的假设出现错误时,你选取的变通办法都会在未来遭遇问题。

一个就近的例子是 flex 元素的默认最小尺寸问题。根据规范的描述,flex 元素初始化的 min-width 和 min-height 的值是 auto (而不是 0),也就是说它们默认应该收缩到自己内容的最小尺寸。但是在过去长达 8 个月的时间里,只有 Firefox 的实现是准确的。[1]

如果你遇到了这个浏览器兼容性的问题并且发现 Chrome、IE、Opera、Safari 的效果相同而 Firefox 和它们不同时,你很可能会认为是 Firefox 搞错了。事实上这种情况我见多了。很多我在自己 Flexbugs 项目上报的问题都是这样的。而且这些解决方案的问题会在两周之后 Chrome 44 修复之后被体现出来。和遵循标准的解决方案相比,这些方案都伤害到了正确的规范行为。[2]

当同一份代码在两个或更多浏览器的渲染结果不同时,你应该花些时间确定哪个效果是正确的,并且以此为标准写代码。你的解决方案应该是对未来友好的。

额外的,所谓“卓越”的前端工程师是时刻感受变化,在某项技术成为主流之前就去适应它的,甚至在为这样的技术做着贡献。如果你锻炼自己看到规范就能在浏览器支持它之前想象出它如何工作的,那么你将成为谈论并影响其规范开发的那群人。
阅读别人的代码

出于乐趣阅读别人的代码可能并不是你每周六晚上会想到的娱乐项目,但是这毫无疑问是你成为优秀工程师的最佳途径。

自己独立解决问题绝对是个不错的方式,但是这不应该是你唯一的方式,因为它很快就会让你稳定在某个层次。阅读别人的代码会让你开阔思维,并且阅读和理解别人写的代码也是团队协作或开源贡献必须具备的能力。

我着实认为很多公司在招聘新员工的时候犯的最大错误是他们只评估应聘者从轮廓开始写新代码的能力。我几乎没有见过一场面试会要求应聘者阅读现有的代码,找出其中的问题,并修复它们。缺少这样的面试流程真的非常不好,因为你作为工程师的很多时间都花费在了在现有的代码的基础上增加或改变上门,而不是搭建新的东西。
与比你聪明的人一起工作

我印象中的很多前端开发者 (相比于全职工作来说) 都是自由职业者,有同类想法的后端开发者并没有那么多。可能是因为很多前端都是自学成才的而后端则多是学校里学出来的。

不论是自我学习还是自我工作,我们都面对一个问题:你并没有机会从比你聪明的家伙那里学到什么。没有人帮你 review 代码,也没有人与你碰撞灵感。

我强烈建议,最起码在你职业发展的前期,你要在一个团队里工作,尤其是一个普遍比你聪明而且有经验的团队里工作。

如果你最终会在你职业发展的某个阶段选择独立工作,一定要让自己投身在开源社区当中。保持对开源项目的活跃贡献,这会给你团队工作相同甚至更多的益处。
“造轮子”

造轮子在商业上是非常糟糕的,但是从学习的角度是非常好的。你可能很想把那些库和小工具直接从 npm 里拿下来用,但也可以想象一下你独立建造它们能够学到多少东西。

我知道有些人读到这里是特别不赞成的。别误会,我并没有说你不应该使用第三方代码。那些经过充分测试的库具有多年的测试用例积累和已知问题积累,使用它们绝对是非常明智的选择。

但在这里我想说的是如何从优秀到卓越。我觉得这个领域很多卓越的人都是我每天在用的非常流行的库的作者或维护者。

你可能不曾打造过自己的 JavaScript 库也拥有一个成功的职业发展,但是你从不把自己手弄脏是几乎不可能淘到金子的。

在这一行大家普遍会问的一个问题是:我接下来应该做点什么?如果你没有试着学一个新的工具创建一个新的应用,那不妨试着重新造一个你喜欢的 JavaScript 库或 CSS 框架。这样做的一个好消息是,在你遇到困难的时候,所有现成的库的源代码都会为你提供帮助。
把你学到的东西都记录下来

最后,但丝毫不逊色的是,你应该把你学到的东西记录下来。这样做有很多原因,但也许最重要的原因是它强迫你更好的理解这件事。如果你无法讲清楚它的工作原理,在整个过程中它会推动你自己把并不真正理解的东西弄清楚。很多情况下你根本意识不到自己还不理解它们——直到自己动手写的时候。

根据我的经验,写作、演讲、做 demo 是强迫自己完全深入理解一件事的最佳方式。就算你写的东西没有人看,整个过程也会让你受益匪浅。
分享到:
评论

相关推荐

    移动前端开发工程师简历.docx

    综上所述,张三作为一名移动前端开发工程师,不仅具备扎实的技术基础,还有丰富的项目经验和良好的团队协作能力,是IT/互联网行业中不可或缺的人才。他的多元化技能和实践经验使他能在各种项目中发挥关键作用,为...

    java 工程师简历

    【Java工程师简历】展示了作者田利斌作为一名Java软件工程师的核心技能和工作经验,他在技术栈上具有广泛的知识和实践经验。...他的经历反映了他追求卓越的品质和持续学习的态度,这是一名优秀Java工程师应具备的素质。

    laravel-developer-learning-resources:Laravel开发人员的学习资源旨在使您成为一名出色的软件工程师

    Laravel 开发者学习资源集合是一个专门为 PHP Laravel 框架的开发者准备的知识宝库,旨在帮助他们提升技能,成为一名卓越的软件工程师。这个资源库包含了多个方面,涵盖了从基础到高级的 Laravel 相关技术,以及与...

    揭秘HTML5和CSS3-鲁超伍

    鲁超伍:网名Adam,热爱互联网,2004年开始接触前端方面的东西,多年互联网前端开发经验,见证了前端开发这个行业的兴起。 现就职于淘宝网北京UED(前端开发工程师...追求卓越,不懈努力,做一个专业的前端开发工程师!

    Blog:个人知识集合整理

    Blog个人技术总结,技术发展方向:目标是一名卓越的软件工程师,从前端入手,让前端能力成为我的杀手锏,同时也能解决其他软件工程方面的能力个人实践,并深入分析之后总结说明:写这些文章,目的是让自己对js基础...

    转正述职报告范文汇总9篇_2.docx

    同时,一名优秀的软件工程师应具备以下技能: - **编程语言**:如Java、JavaScript等。 - **前端技术**:HTML、CSS、JavaScript等用于构建用户界面的技术。 - **后端技术**:数据库管理、服务器配置等。 - **问题...

    个人简历1

    首先,该简历的主人苏老师是一名专注于Java后端开发的大三学生,具备扎实的软件工程专业基础。Java作为主要编程语言,被广泛应用于企业级应用开发,Java SE和Java EE是其核心部分,分别代表了Java的标准版和企业版,...

    SONY EFFIO资料.zip

    这个ZIP压缩包文件名为"SONY EFFIO资料.zip",包含了一系列关于CXD4129、4813、4816及5148等型号的电路原理图,这些资料对于理解和应用索尼EFFIO技术具有重要的参考价值,特别是针对DFFIO技术的部分。 首先,我们来...

    Axure学习资料产品经理需要具备的六要素

    ### Axure学习资料:产品经理需要...总之,成为一名优秀的产品经理并非易事,它需要不断学习和实践。通过上述六个要素的学习和实践,可以帮助产品经理提升自己的专业能力和职业竞争力,最终打造出真正有价值的产品。

    虚拟全书(核心语言)

    Mathematica的主要特点之一是其内建的函数库,覆盖了从简单的数值计算到复杂的数学模型分析,为科研人员、工程师和学生提供了极大的便利。 在Mathematica中,Notebooks是核心的交互方式之一。Notebook文档支持富...

    front-end

    在实际开发中,前端工程师会结合现代前端框架和库(如Angular、React或Vue.js)以及模块化工具(如ES6模块或CommonJS)来提高开发效率和代码复用。此外,还会利用如Git进行版本控制,确保代码的安全和协同工作。总之...

    源代码网站集合

    清秋源码是一个ASP源码分享站点,提供的源码资源侧重于Web开发,尤其是动态网站和Web应用的构建,对于从事Web开发的工程师来说,是一个值得信赖的资源库。 以上列举的源代码网站集合,覆盖了从基础到高级、从理论到...

    igti-bootcamp-fullstack-developer:IGTI的全栈开发人员训练营

    通过IGTI的全栈开发人员训练营,学员将不仅学习到JavaScript编程,还将获得实际项目开发经验,提升问题解决能力,最终成为一名能够独立完成从客户端到服务器端的全方位开发工作的全栈工程师。训练营的项目实践部分...

    美信采集系统提供FPGA模拟I/O设计,有效加速产品上市

    其在2014年9月9日于北京发布了一款名为MAXREFDES74#的高速、18位数据采集系统(DAS)参考设计,针对FPGA(Field-Programmable Gate Array)工程师,旨在加速基于FPGA的控制系统评估、验证以及产品上市的时间表。...

    电商优秀团队推荐理由范文.doc

    这19名成员不仅具备专业的技术背景,还拥有敏锐的市场洞察力,能够准确预测市场趋势,确保前端市场的布局和后端供应链的稳定。他们已经涉足5G通讯模组、医疗、汽车和物联网等多元化产品市场,展现出强大的市场拓展...

    模拟技术中的TI 推出最低失真的16位运算放大器

    TI(德州仪器)近期发布了一款名为THS4520的高性能全差动运算放大器,这是一款专为驱动高分辨率高速ADC(模数转换器)设计的器件,适用于各种高精度应用,如无线通信、测量与测试、医学成像等。THS4520具备了轨至轨...

Global site tag (gtag.js) - Google Analytics